InetAddress 解析

IP地址分为IPv4 和IPv6。

IPv4

4字节长的ip称为IPv4.目前大部分ip都是IPv4。 IPv4地址一般写为四哥无符号的字节,每个字节范围从0到255,最高字节在前面。为方便人们查看,各字节用点号分割。 例如:192.168.1.100.这称为点分四段格式。

IPv6

16字节长的ip成为IPv6. IPv6地址通常些微冒号分割的8个区块,每个区块4个十六进制数字。 例如:2400:cb00:2048:1:0:0:6ca2:c665

两个冒号标识多个0区块,但每个地址中双冒号之多出现一次。 例如:2001:1234:4567:0000:0000:0000:8888可以缩写为 2001:1234:4567::8888。

IPv6和IPv4的混合网络中,IPv6地址的最后4字节有时些微IPv4的点分四段地址。 例如:2001:1234:4567::c0a8:0a64可以写为 2001:1234:4567::192.168.10.100

ip地址对于计算机来说很不错,但位于人来说是个问题,于是就发明了域名系统(Domain Name System, DNS)。DNS将人们可以记忆的主机名与计算机可以记忆的IP地址关联在一起。服务器至少有一个主机名。客户端往往有一个主机名,但也可能没有,特别是有些客户端的IP地址会在启动的时候动态指定。

IP地址和域名可以1:1、 1:多 、 多:1 、 多:多。 可以通过一个域名对应多个ip,来实现DNS的负载均衡。

InetAddress类

java.net.IntAddress类是java对IP地址的高层表示。大多数其它网络类都要用到这个类,包括Socket、ServerSocket、URL、DatagramSocket、DatagramPacket等。它包括一个主机名和一个IP地址。

创建InetAddress 对象

  1. 根据域名创建InetAddress对象 InetAddress addr1 = InetAddress.getByName("www.baidu.com");

[HostName : www.baidu.com] [HostAddress: 220.181.112.244]

  1. 根据ip创建InetAddress对象 InetAddress addr2 = InetAddress.getByName("220.181.112.244");

[HostName : 220.181.112.244] [HostAddress: 220.181.112.244] 如果获取不到主机名就返回ip

  1. 根据主机名创建InetAddress对象 InetAddress addr3 = InetAddress.getByName("IFC-PCB-094");

[HostName : IFC-PCB-094] [HostAddress: 192.168.3.249]

  1. 获取本机的InetAddress,如果获取不到(可能是安全问题)就会返回 地址:127.0.0.1 和 主机名:localhost InetAddress addr4 = InetAddress.getLocalHost();

[HostName : IFC-PCB-094] [HostAddress: 192.168.3.249]

  1. 根据 ip字节数组创建 InetAddress 对象 public static InetAddress getByAddress(byte[] addr) InetAddress addr = InetAddress.getByAddress(new byte[]{-64,-88,0,1});

[HostName : jijs] [HostAddress: 192.168.0.1]

  1. 根据域名和 ip字节数组创建 InetAddress 对象 InetAddress addr = InetAddress.getByAddress("jijs",new byte[]{-64,-88,0,1});

[HostName : jijs] [HostAddress: 192.168.0.1]

  1. 获取该主机的所有的地址,返回一个InetAddress[] 对象 public static InetAddress[] getAllByName(String host)
InetAddress[] addr = InetAddress.getAllByName("www.baidu.com");
for (InetAddress inetAddress : addr) {
    System.out.println(inetAddress);
}

输出: www.baidu.com/220.181.112.244 www.baidu.com/220.181.111.188

获取方法

//获取主机名
public String getHostName();
//获取主机名(每次方法都解析DNS去获取主机名,而不从缓存中获取)
public String getCanonicalHostName();
//获取以字节数组形式的ip地址。
public byte[] getAddress();
//获取点分四段式ip。
public String getHostAddress();
  1. getHostName() 该方法返回主机名或ip。如果这台机器没有主机名或者安全管理器阻止确定主机名,就会返回四段式ip地址,否则返回主机名。
  2. getCanonicalHostName() 获取主机名,每次方法都解析DNS去获取主机名,而不从缓存中获取。
  3. getAddress() 获取ip地址的字节数组,如果IPv4则返回4个长度的字节数组,如果是IPv6则返回16个长度的字节数组。 我们可以根据返回的字节长度来判断是IPv4还是IPv6。
  4. getHostAddress() 返回一个点分四段式ip字符串。

地址类型

public boolean isMulticastAddress();
public boolean isAnyLocalAddress();
public boolean isLoopbackAddress();
public boolean isLinkLocalAddress();
public boolean isSiteLocalAddress();
public boolean isMCGlobal();
public boolean isMCNodeLocal();
public boolean isMCLinkLocal();
public boolean isMCSiteLocal();
public boolean isMCOrgLocal();
  1. isMulticastAddress() 当IP地址是广播地址(MulticastAddress)时返回true,否则返回false。 通过广播地址可以向网络中的所有计算机发送信息,而不是只向一台特定的计算机发送信息。IPv4的广播地址的范围是224.0.0.0 ~ 239.255.255.255.IPv6的广播地址第一个字节是FF,其他的字节可以是任意值。
  2. isAnyLocalAddress() 当IP地址是通配符地址时返回true,否则返回false。 IPv4的通配符地址是0.0.0.0 IPv6的通配符地址是0:0:0:0:0:0:0:0,也可以简写成::。
  3. isLoopbackAddress() 当IP地址是loopback地址时返回true,否则返回false。 loopback地址就是代表本机的IP地址。 IPv4的loopback地址的范围是127.0.0.0 ~ 127.255.255.255,也就是说,只要第一个字节是127,就是lookback地址。如127.1.2.3、127.0.200.200都是loopback地址。 IPv6的loopback地址是0:0:0:0:0:0:0:1,也可以简写成::1
  4. isLinkLocalAddress() 当IP地址是本地连接地址(LinkLocalAddress)时返回true,否则返回false。 IPv4的本地连接地址的范围是169.254.0.0 ~ 169.254.255.255。 IPv6的本地连接地址的前12位是FE8,其他的位可以是任意取值,如FE88::和FE80::ABCD::都是本地连接地址。
  5. isSiteLocalAddress() 当IP地址是地区本地地址(SiteLocalAddress)时返回true,否则返回false。(是不是内网ip) IPv4的地址本地地址分为三段:10.0.0.0 ~ 10.255.255.255、172.16.0.0 ~ 172.31.255.255、192.168.0.0 ~ 192.168.255.255。(企业内部或个人内部的局域网内部的ip都应该在此三个网段内) IPv6的地区本地地址的前12位是FEC,其他的位可以是任意取值,如FED0:: 和 FEF1:: 都是地区本地地址。
  6. isMCGlobal() 当IP地址是全球范围的广播地址时返回true,否则返回false。 全球范围的广播地址可以向Internet中的所有的计算机发送信息。 IPv4的广播地址除了224.0.0.0和第一个字节是239的IP地址都是全球范围的广播地址。 IPv6的全球范围的广播地址中第一个字节是FF,第二个字节的范围是0E ~ FE,其他的字节可以是任意值,如FFBE::、FF0E::都是全球范围的广播地址。
  7. isMCNodeLocal() 当IP地址是本地接口广播地址时返回true,否则返回false。 本地接口广播地址不能将广播信息发送到产生广播信息的网络接口,即使是同一台计算机的另一个网络接口也不行。所有的IPv4广播地址都不是本地接口广播地址。IPv6的本地接口广播地址的第一个字节是FF,第二个节字的范围是01 ~ F1,其他的字节可以是任意值,如FFB1::、FF01:A123::都是本地接口广播地址。
  8. isMCLinkLocal() 当IP地址是子网广播地址时返回true,否则返回false。 使用子网的广播地址只能向子网内的计算机发送信息。 IPv4的子网广播地址的范围是224.0.0.0 ~ 224.0.0.255。 IPv6的子网广播地址的第一个字节是FF,第二个字节的范围是02 ~ F2,其他的字节可以是任意值,如FFB2:: 和 FF02:ABCD:: 都是子网广播地址。
  9. isMCSiteLocal() 当IP地址是站点范围的广播地址时返回true,否则返回false。 使用站点范围的广播地址,可以向站点范围内的计算机发送广播信息。 IPv4的站点范围广播地址的范围是239.255.0.0 ~ 239.255.255.255,如239.255.1.1、239.255.0.0都是站点范围的广播地址。 IPv6的站点范围广播地址的第一个字节是FF,第二个字节的范围是05 ~ F5,其他的字节可以是任意值,如FF05:: 和 FF45:: 都是站点范围的广播地址。
  10. isMCOrgLocal() 当IP地址是组织范围的广播地址时返回ture,否则返回false。 使用组织范围广播地址可以向公司或企业内部的所有的计算机发送广播信息。 IPv4的组织范围广播地址的第一个字节是239,第二个字节不小于192,第三个字节不大于195,如239.193.100.200、239.192.195.0都是组织范围广播地址。 IPv6的组织范围广播地址的第一个字节是FF,第二个字节的范围是08 ~ F8,其他的字节可以是任意值,如FF08:: 和 FF48::都是组织范围的广播地址。

可达性测试

//可以根据指定timeout时间内测试网络是否可达,是否可以建立连接。 public boolean isReachable(int timeout) //可以指定从本机那个网卡、生存时间ttl 和指定时间来测试网络是否可达。 public boolean isReachable(NetworkInterface netif, int ttl, int timeout)

Inet4Address 和 Inet6Address

上面调用构造InetAddress,和获取一些信息,其实都是委托给Inet4Address或Inet6Address中的方法。

Paste_Image.png

从代码中可以看出,是根据ip地址字节数组长度来判断创建Inet4Address实例还是Inet6Address实例。

Inet4Address类结构图


本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏美团技术团队

高性能队列——Disruptor

背景 Disruptor是英国外汇交易公司LMAX开发的一个高性能队列,研发的初衷是解决内存队列的延迟问题(在性能测试中发现竟然与I/O操作处于同样的数量级)。...

613110
来自专栏Zephery

Spring项目路径

Spring源码——WebUtils 个人网站中部署的服务器共有两台,由于是分布式的环境,为了防止有效的针对具体某个服务器出现的问题,需要在网页上加上服务器的I...

37340
来自专栏草根专栏

从头编写 asp.net core 2.0 web api 基础框架 (4) EF配置

Github源码地址:https://github.com/solenovex/Building-asp.net-core-2-web-api-starter-...

79470
来自专栏玄魂工作室

CTF实战32 综合实战和讲解二

该培训中提及的技术只适用于合法CTF比赛和有合法授权的渗透测试,请勿用于其他非法用途,如用作其他非法用途与本文作者无关

8430
来自专栏草根专栏

使用xUnit为.net core程序进行单元测试(1)

一. 导读 为什么要编写自动化测试程序(Automated Tests)? 可以频繁的进行测试 可以在任何时间进行测试,也可以按计划定时进行,例如:可以在半夜进...

34850
来自专栏分布式系统进阶

Cluster版本中的Meta

11840
来自专栏公众号_薛勤的博客

深入理解[Master-Worker模式]原理与技术

Master-Worker模式是常用的并行模式之一。它的核心思想是,系统由两类进程协作工作:Master进程和Worker进程。Master进程负责接收和分配任...

25050
来自专栏Hadoop实操

如何开发HBase Endpoint类型的Coprocessor以及部署使用

37820
来自专栏向治洪

多线程断点下载

多线程断点下载 多线程下载 public class MultiThreadDownloader { private URL url; // 目...

20150
来自专栏逆向与安全

网秦安全盾 原理分析

环境: 手机: 中兴 u887 系统 android2.3.5 调试器: IDA pro 6.5

11700

扫码关注云+社区

领取腾讯云代金券