欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java編程中利用InetAddress類確定特殊IP地址的方法

 更新時(shí)間:2015年11月05日 08:57:39   作者:Rainbow702  
這篇文章主要介紹了Java編程中利用InetAddress類確定特殊IP地址的方法,InetAddress類是Java網(wǎng)絡(luò)編程中一個(gè)相當(dāng)實(shí)用的類,需要的朋友可以參考下

InetAddress類

InetAddress類用來封裝我們前面討論的數(shù)字式的IP地址和該地址的域名。

  你通過一個(gè)IP主機(jī)名與這個(gè)類發(fā)生作用,IP主機(jī)名比它的IP地址用起來更簡便更容易理解。

  InetAddress類內(nèi)部隱藏了地址數(shù)字。

 
InetAddress類中的工廠方法
  InetAddress類沒有明顯的構(gòu)造函數(shù)。為生成一個(gè)InetAddress對(duì)象,必須運(yùn)用一個(gè)可用的工廠方法。

  工廠方法(factory method)僅是一個(gè)類中靜態(tài)方法返回一個(gè)該類實(shí)例的約定。

  對(duì)于InetAddress,三個(gè)方法:getLocalHost()、getByName()以及getAllByName()可以用來創(chuàng)建InetAddress的實(shí)例。

  

  getLocalHost()僅返回象征本地主機(jī)的InetAddress對(duì)象。

  本機(jī)地址還為localhost,127.0.0.1,這三個(gè)地址都是一回事。

 

  getByName()方法返回一個(gè)傳給它的主機(jī)名的InetAddress。

  如果這些方法不能解析主機(jī)名,它們引發(fā)一個(gè)UnknownHostException異常。

 

  在Internet上,用一個(gè)名稱來代表多個(gè)機(jī)器是常有的事。

  getAllByName()工廠方法返回代表由一個(gè)特殊名稱分解的所有地址的InetAddresses類數(shù)組。

  在不能把名稱分解成至少一個(gè)地址時(shí),它將引發(fā)一個(gè)UnknownHostException異常。

 

程序?qū)嵗?br /> InetAddressTest01

package com.example.network;

import java.net.InetAddress;

public class InetAddressTest01
{
  public static void main(String[] args) throws Exception
  {
    InetAddress address = InetAddress.getLocalHost();

    System.out.println(address);
    // 輸出:機(jī)器名/IP地址
    // 如username-PC/10.4.16.131

    // 通過域名得到IP地址
    address = InetAddress.getByName("www.sohu.com");
    System.out.println(address);
    // 輸出:域名/IP地址
  }

}

利用InetAddress類確定特殊IP地址
IP地址分為普通地址和特殊地址。在前面的文章中所使用的大多數(shù)都是普通的IP地址,在本文中將介紹如何利用InetAddress類提供的十個(gè)方法來確定一個(gè)IP地址是否是一個(gè)特殊的IP地址。
    一、isAnyLocalAddress方法
    當(dāng)IP地址是通配符地址時(shí)返回true,否則返回false.這個(gè)通配符地址對(duì)于擁有多個(gè)網(wǎng)絡(luò)接口(如兩塊網(wǎng)卡)的計(jì)算機(jī)非常擁有。使用通配符地址可以允許在服務(wù)器主機(jī)接受來自任何網(wǎng)絡(luò)接口的客戶端連接。IPv4的通配符地址是0.0.0.0.IPv6的通配符地址是0:0:0:0:0:0:0:0,也可以簡寫成::。
    二、isLoopbackAddress方法
    當(dāng)IP地址是loopback地址時(shí)返回true,否則返回false.loopback地址就是代表本機(jī)的IP地址。IPv4的loopback地址的范圍是127.0.0.0 ~ 127.255.255.255,也就是說,只要第一個(gè)字節(jié)是127,就是lookback地址。如127.1.2.3、127.0.200.200都是loopback地址。IPv6的loopback地址是0:0:0:0:0:0:0:1,也可以簡寫成::1.我們可以使用ping命令來測試lookback地址。如下面的命令行所示:

ping 127.200.200.200 

運(yùn)行結(jié)果:

Reply from 127.0.0.1: bytes=32 time<1ms TTL=128  (注:win7下是127.200.200.200)
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128

Ping statistics for 127.200.200.200:
    Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
    Minimum = 0ms, Maximum = 0ms, Average = 0ms

雖然127.255.255.255也是loopback地址,但127.255.255.255在Windows下是無法ping通的。這是因?yàn)?27.255.255.255是廣播地址,在Windows下對(duì)發(fā)給廣播地址的請(qǐng)求不做任何響應(yīng),而在其他操作系統(tǒng)上根據(jù)設(shè)置的不同,可能會(huì)得到不同的結(jié)果。
    三、isLinkLocalAddress方法
    當(dāng)IP地址是本地連接地址(LinkLocalAddress)時(shí)返回true,否則返回false.IPv4的本地連接地址的范圍是169.254.0.0 ~ 169.254.255.255.IPv6的本地連接地址的前12位是FE8,其他的位可以是任意取值,如FE88::、FE80::ABCD::都是本地連接地址。
    四、isSiteLocalAddress方法
    當(dāng)IP地址是地區(qū)本地地址(SiteLocalAddress)時(shí)返回true,否則返回false.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.IPv6的地區(qū)本地地址的前12位是FEC,其他的位可以是任意取值,如FED0::、FEF1::都是地區(qū)本地地址。
    五、isMulticastAddress方法
    當(dāng)IP地址是廣播地址(MulticastAddress)時(shí)返回true,否則返回false.通過廣播地址可以向網(wǎng)絡(luò)中的所有計(jì)算機(jī)發(fā)送信息,而不是只向一臺(tái)特定的計(jì)算機(jī)發(fā)送信息。IPv4的廣播地址的范圍是224.0.0.0 ~ 239.255.255.255.IPv6的廣播地址第一個(gè)字節(jié)是FF,其他的字節(jié)可以是任意值。關(guān)于廣播地址的詳細(xì)內(nèi)容將在以后的章節(jié)中討論。
    六、isMCGlobal方法
    當(dāng)IP地址是全球范圍的廣播地址時(shí)返回true,否則返回false.全球范圍的廣播地址可以向Internet中的所有的計(jì)算機(jī)發(fā)送信息。IPv4的廣播地址除了224.0.0.0和第一個(gè)字節(jié)是239的IP地址都是全球范圍的廣播地址。IPv6的全球范圍的廣播地址中第一個(gè)字節(jié)是FF,第二個(gè)字節(jié)的范圍是0E ~ FE,其他的字節(jié)可以是任意值,如FFBE::、FF0E::都是全球范圍的廣播地址。
    七、isMCLinkLocal方法
    當(dāng)IP地址是子網(wǎng)廣播地址時(shí)返回true,否則返回false.使用子網(wǎng)的廣播地址只能向子網(wǎng)內(nèi)的計(jì)算機(jī)發(fā)送信息。IPv4的子網(wǎng)廣播地址的范圍是224.0.0.0 ~ 224.0.0.255.IPv6的子網(wǎng)廣播地址的第一個(gè)字節(jié)是FF,第二個(gè)字節(jié)的范圍是02 ~ F2,其他的字節(jié)可以是任意值,如FFB2::、FF02:ABCD::都是子網(wǎng)廣播地址。
    八、isMCNodeLocal方法
    當(dāng)IP地址是本地接口廣播地址時(shí)返回true,否則返回false.本地接口廣播地址不能將廣播信息發(fā)送到產(chǎn)生廣播信息的網(wǎng)絡(luò)接口,即使是同一臺(tái)計(jì)算機(jī)的另一個(gè)網(wǎng)絡(luò)接口也不行。所有的IPv4廣播地址都不是本地接口廣播地址。IPv6的本地接口廣播地址的第一個(gè)字節(jié)是FF,第二個(gè)節(jié)字的范圍是01 ~ F1,其他的字節(jié)可以是任意值,如FFB1::、FF01:A123::都是本地接口廣播地址。
    九、isMCOrgLocal方法
    當(dāng)IP地址是組織范圍的廣播地址時(shí)返回ture,否則返回false.使用組織范圍廣播地址可以向公司或企業(yè)內(nèi)部的所有的計(jì)算機(jī)發(fā)送廣播信息。IPv4的組織范圍廣播地址的第一個(gè)字節(jié)是239,第二個(gè)字節(jié)不小于192,第三個(gè)字節(jié)不大于195,如239.193.100.200、239.192.195.0都是組織范圍廣播地址。IPv6的組織范圍廣播地址的第一個(gè)字節(jié)是FF,第二個(gè)字節(jié)的范圍是08 ~ F8,其他的字節(jié)可以是任意值,如FF08::、FF48::都是組織范圍的廣播地址。
    十、isMCSiteLocal方法
    當(dāng)IP地址是站點(diǎn)范圍的廣播地址時(shí)返回true,否則返回false.使用站點(diǎn)范圍的廣播地址,可以向站點(diǎn)范圍內(nèi)的計(jì)算機(jī)發(fā)送廣播信息。IPv4的站點(diǎn)范圍廣播地址的范圍是239.255.0.0 ~ 239.255.255.255,如239.255.1.1、239.255.0.0都是站點(diǎn)范圍的廣播地址。IPv6的站點(diǎn)范圍廣播地址的第一個(gè)字節(jié)是FF,第二個(gè)字節(jié)的范圍是05 ~ F5,其他的字節(jié)可以是任意值,如FF05::、FF45::都是站點(diǎn)范圍的廣播地址。
 
下面的代碼可以確定一個(gè)IP地址是否在上述十種地址類型的范圍內(nèi):

package test;

import java.net.*;
import java.lang.reflect.*;

public class MyNet
{
  public static void main(String[] args) throws Exception
  {
    if (args.length == 0)
      return;
    InetAddress address = InetAddress.getByName(args[0]);
    Method methods[] = InetAddress.class.getMethods();
    // 以is開頭并且沒有參數(shù)的方法
    for (Method method : methods)
    {
      if (method.getName().matches("is.*") && method.getParameterTypes().length == 0)
      {
        if (Boolean.parseBoolean(method.invoke(address).toString()))
          System.out.println(method.getName() + " = true");
      }
    }
  }
}

測試1
    執(zhí)行如下命令:

java test.MyNet 224.0.0.1

運(yùn)行結(jié)果:

isMCLinkLocal = true
isMulticastAddress = true

測試2
    執(zhí)行如下命令:

java test.MyNet FFB1::

運(yùn)行結(jié)果:

isMCNodeLocal = true 
isMulticastAddress = true 

相關(guān)文章

  • Java的JDBC和橋接模式詳解

    Java的JDBC和橋接模式詳解

    下面小編就為大家?guī)硪黄狫ava的JDBC和橋接模式(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-09-09
  • DispatcherServlet處理器的適配和處理解析

    DispatcherServlet處理器的適配和處理解析

    這篇文章主要為大家介紹了DispatcherServlet的處理器的適配和處理流程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(18)

    Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(18)

    下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-07-07
  • 解析Spring事件發(fā)布與監(jiān)聽機(jī)制

    解析Spring事件發(fā)布與監(jiān)聽機(jī)制

    本篇文章給大家介紹Spring事件發(fā)布與監(jiān)聽機(jī)制,通過 ApplicationEvent 事件類和 ApplicationListener 監(jiān)聽器接口,可以實(shí)現(xiàn) ApplicationContext 事件發(fā)布與處理,需要的朋友參考下吧
    2021-06-06
  • Java Swagger使用教程

    Java Swagger使用教程

    Swagger是一個(gè)規(guī)范和完整的框架,用于生成、描述、調(diào)用和可視化 Restful 風(fēng)格的 Web 服務(wù)??傮w目標(biāo)是使客戶端和文件系統(tǒng)作為服務(wù)器以同樣的速度來更新。文件的方法、參數(shù)和模型緊密集成到服務(wù)器端的代碼,允許API來始終保持同步
    2022-07-07
  • Java網(wǎng)絡(luò)編程之UDP網(wǎng)絡(luò)通信詳解

    Java網(wǎng)絡(luò)編程之UDP網(wǎng)絡(luò)通信詳解

    這篇文章主要為大家詳細(xì)介紹了Java網(wǎng)絡(luò)編程中的UDP網(wǎng)絡(luò)通信的原理與實(shí)現(xiàn),文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下
    2022-09-09
  • Springboot中使用Redisson+AOP+自定義注解實(shí)現(xiàn)訪問限流與黑名單攔截

    Springboot中使用Redisson+AOP+自定義注解實(shí)現(xiàn)訪問限流與黑名單攔截

    本文主要介紹了Springboot中使用Redisson+AOP+自定義注解實(shí)現(xiàn)訪問限流與黑名單攔截,包含針對(duì)用戶IP限流,整個(gè)接口的訪問限流,以及對(duì)某個(gè)參數(shù)字段的限流,并且支持請(qǐng)求限流后處理回調(diào),感興趣的可以了解一下
    2024-02-02
  • Spring中@ExceptionHandler注解的使用方式

    Spring中@ExceptionHandler注解的使用方式

    這篇文章主要介紹了Spring中@ExceptionHandler注解的使用方式,@ExceptionHandler注解我們一般是用來自定義異常的,可以認(rèn)為它是一個(gè)異常攔截器(處理器),需要的朋友可以參考下
    2024-01-01
  • Java死鎖問題詳解及示例

    Java死鎖問題詳解及示例

    本文將討論Java程序中死鎖問題的概念、產(chǎn)生原因以及避免策略。同時(shí),我們還將通過代碼示例來進(jìn)一步闡述這個(gè)問題,感興趣的小伙伴可以跟著小編一起來學(xué)習(xí)
    2023-04-04
  • 談?wù)刯ava的concurrent用法

    談?wù)刯ava的concurrent用法

    這篇文章給大家介紹java的concurrent用法,感興趣的朋友一起學(xué)習(xí)吧
    2015-10-10

最新評(píng)論