如何判断自己IP是内网IP还是外网IP

简介: tcp/ip协议中,专门保留了三个IP地址区域作为私有地址,其地址范围如下: 10.0.0.0/8:10.0.0.0~10.255.255.255   172.16.0.0/12:172.16.0.0~172.31.255.255   192.168.0.0/16:192.168.0.0~192.168.255.255 使用保留地址的网络只能在内部进行通信,而不能与其他网络互连。

  tcp/ip协议中,专门保留了三个IP地址区域作为私有地址,其地址范围如下:

10.0.0.0/8:10.0.0.0~10.255.255.255 
  172.16.0.0/12:172.16.0.0~172.31.255.255 
  192.168.0.0/16:192.168.0.0~192.168.255.255
使用保留地址的网络只能在内部进行通信,而不能与其他网络互连。如果要与外部通信,那么必须通过网关与外部通信,这里使用了NAT, NAPT技术就是用来保证通信的代理机制。
 
       另外,一些宽带运营商尽管也使用了非私有地址分配给用户使用,但是由于路由设置的原因,Internet上的其他用户并不能访问到这些ip。上面2部分IP都可称为内网IP,下面这部分IP不列入本次讨论范围。
 
如果自己机器上网络接口的ip地址落在上述保留地址的范围内,则可以肯定自己处于内网模式下。
NAT要求整个服务的连接是从内网向外网主动发起的,而外网的用户无法直接(主动)向内网的服务发起连接请求,除非在NAT的(所有)网关上针对服务的端口作了端口映射。NAT方式要求最外围的网关至少有一个公网的IP,可以访问显IP的外部服务器获取到外部IP,将这个IP与自己机器上网络接口的ip比较,即可知道自己的ip是不是内网IP。
 
判断自己IP类型,可使用下面三种任意一种方法:
1)      在windos命令台程序下,用ipconfig。
Eg: 下面内网IP是192.168.0.1,外网IP是125.34.47.25,因此是网关。
C:/Documents and Settings/user>ipconfig
 
Windows IP Configuration
Ethernet adapter 本地连接:
        Connection-specific DNS Suffix . :
        IP Address. . . . . . . . . . . . : 192.168.0.1
        Subnet Mask . . . . . . . . . . . : 255.255.255.0
        Default Gateway . . . . . . . . . : 192.168.0.1
 
Ethernet adapter {6C8AEC26-0EC3-40FE-812E-A46778ECA752}:
        Media State . . . . . . . . . . . : Media disconnected
 
PPP adapter 宽带拨号:
        Connection-specific DNS Suffix . :
        IP Address. . . . . . . . . . . . : 125.34.47.25
        Subnet Mask . . . . . . . . . . . : 255.255.255.255
        Default Gateway . . . . . . . . . : 125.34.47.25
 
2)      用tracert来判断IP类型
如果第一个hops不是内网IP,那么自己就是外网IP了,反之,如果自己是内网IP,那么第一个hops显示的就是网关的内网IP,下面的例子显然说明是外网IP了。
C:/Documents and Settings/user>tracert www.baidu.com
 
Tracing route to www.a.shifen.com [202.108.22.5]
over a maximum of 30 hops:
 1    15 ms    16 ms    14 ms 125.34.40.1
 2   14 ms     *        *     61.148.8.9
 3    26 ms    72 ms    40 ms xd-22-5-a8.bta.net.cn [202.108.22.5]
 
Trace complete.
 
3)编程实现
获取到本机所有的IP地址列表,对IP列表进行分析:
1) 如果列表中只有局域网IP,那么说明是在内网;
2) 如果列表中有局域网IP,也有公网IP,那么说明是网关;
3) 如果列表中只有公网IP,那么说明是独立IP。
//此处不考虑其它平台,在inet架构下测试, 输入的ip为主机字节顺序
// 0xa -- "10.0.0.0">>24; 0xc0a8--"192.168.0.0.">>16; 0x2b0--"127.17.0.1">>22
int isInnerIP( uint32_t a_ip )
{
       int bValid = -1;
       if( (a_ip>>24 == 0xa) || (a_ip>>16 == 0xc0a8) || (a_ip>>22 == 0x2b0) )
       {
          bValid = 0;
       }
       return bValid;
}
int isInnerIP( char* a_strip )
{
       return 0;
}
IP相关的应用
//获取到本机所有的IP地址列表,并分别用字符串与整形形式来显示
int getHostIP()       //return int
{
       struct sockaddr_in localAddr, destAddr;
       struct hostent* h;
       char temp[128];
 
       int nRect = gethostname(temp, 128);
       printf("ipaddr src3 is: %s/n", temp);
       if(nRect !=0)
       {
              printf("error");
       }
       h = gethostbyname(temp);
       if(h)
       {
              for(int nAdapter=0; h->h_addr_list[nAdapter]; nAdapter++)
              {
                     memcpy(&destAddr.sin_addr.s_addr, h->h_addr_list[nAdapter], h->h_length);
                     // 输出机器的IP地址.
                     printf("Address string: %s/n", inet_ntoa(destAddr.sin_addr)); // 显示地址串
                     printf("Address int: %d/n", destAddr.sin_addr.s_addr); // 转化为整形数字
              }
       }
       return     0;
}
 
//检查字符串IP是否合法
int isCheckTrue(char* strip)
{
       int value;
       for( int i = 0; i < strlen(strip); i++)
       {
       // let's check if all entered char in entered
       // IP address are digits
              if(strip[i] == '.')
                     continue;
 
              if(isdigit(strip[i]) == 0)
              {
                     return -1;
              }
       }
       return 0;
}
//将字符串IP转化为整形IP
int str2intIP(char* strip) //return int ip
{
       int intIP;
       if(!(intIP = inet_addr(strip)))
       {
              perror("inet_addr failed./n");
              return -1;
       }
       return intIP;
}
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
安全 搜索推荐 网络架构
什么是内网和外网?什么是内网IP和外网IP?本地连接和宽带连接又有什么区别?
何为内网外网迷糊?究竟什么是内网?什么是外网?他们又有和区别?还有什么是内网IP和外网IP?本地连接和宽带连接有什么区别?怂怂今天就来给大家科普一下吧:
15594 0
|
Web App开发 应用服务中间件 PHP
IPv4内网与公网地址范围
本文介绍了内网和公网IPv4地址的范围及用途。内网IP(私有地址)包括10.0.0.0/8、172.16.0.0/12和192.168.0.0/16,分别适用于大型、中型和小型网络。公网IP分为A、B、C类,分别支持大规模、中等规模和小规模网络;D类用于多播通信,E类保留实验用途。此外,127.0.0.0/8为环回地址,不用于公网。这些划分确保了IP地址的有效利用与网络通信的正常进行。
5947 10
|
3月前
|
人工智能 安全 图形学
OpenClaw(Clawdbot)阿里云+本地部署攻略:+Claude Code ECC、OMC插件兼容指南
在AI编程工具生态中,Claude Code的两大核心插件everything-claude-code(ECC)与oh-my-claudecode(OMC)以极强的互补性成为开发者首选:ECC聚焦工程质量,构建Rules规范体系与Agents专家团队,守住“90分质量门禁”;OMC主打工作流增强,凭借持久化记忆与多模型协作,实现“高效执行闭环”。但两者同时安装时的Agent命名冲突,成为困扰开发者的核心痛点。
2493 1
|
4月前
|
人工智能 网络协议 机器人
2026年OpenClaw(原ClawdBot)部署接入QQ/飞书/钉钉/微信喂饭教程(阿里云专属,零基础保姆级)
2026年,OpenClaw(原ClawdBot,曾用名Moltbot)凭借“自然语言驱动+多任务自动化执行+全渠道适配”的核心优势,成为开源AI智能体赛道的现象级项目,GitHub星标数突破18.6万,吸引了无数个人用户和企业团队投身部署使用。作为一款定位为“真正能干事情的AI”,OpenClaw的核心价值不仅在于自动化办公、代码辅助、网页抓取等基础功能,更在于其强大的多渠道对接能力——可无缝接入QQ、飞书、钉钉、微信(喂饭模式)四大主流通讯工具,让AI助理突破Web控制台的限制,融入日常聊天场景,实现“聊两句就能下达指令、完成任务”。
2949 6
|
Ubuntu 开发工具
Ubuntu更换阿里云软件源
Ubuntu更换阿里云软件源
147203 0
Debian 官方源换为国内的源的操作方法
apt-get update 报错,采用更换源的方式解决问题。
59769 0
|
人工智能 缓存 NoSQL
告别繁琐:AI 工具 1 天搞定秒杀系统,代码全公开
秒杀系统是电商领域吸引流量和促进销售的重要工具,但传统开发面临高并发、库存超卖、缓存击穿等问题,耗时耗力。如今,AI工具如飞算JavaAI可自动生成高质量Java代码,例如Redis + Lua分布式锁,解决高并发下的锁问题,大幅提升QPS并优化响应时间。通过AI生成代码,不仅能有效应对缓存击穿和库存超卖等挑战,还显著缩短开发周期至1天,为高并发系统开发带来革命性变化。
IPv4内网与公IPv4地址范围
内网IPv4地址包括10.0.0.0/8(适用于大型组织)、172.16.0.0/12(适合中等规模网络)和192.168.0.0/16(常用于家庭或小型办公室)。公网IPv4地址分为Class A(大规模网络,如0.0.0.0-127.255.255.255),Class B(中等规模,128.0.0.0-191.255.255.255),Class C(小规模,192.0.0.0-223.255.255.255),Class D(多播,224.0.0.0-239.255.255.255)和Class E(实验用途,240.0.0.0-255.255.255.255)。
5467 2
Request Headers 中的 Accept 是 text/event-stream
Request Headers 中的 Accept 是 text/event-stream
2481 0