JAVA中IP和整数相互转化的方法

 更新时间:2015年05月29日 15:06:42   作者:wo_soul  
这篇文章主要介绍了JAVA中IP和整数相互转化的方法,涉及java数值转换的相关技巧,需要的朋友可以参考下

本文实例讲述了JAVA中IP和整数相互转化的方法。分享给大家供大家参考。具体分析如下:

一、基本知识点

IP ——> 整数:
把IP地址转化为字节数组
通过左移位(<<)、与(&)、或(|)这些操作转为int
整数 ——> IP:
将整数值进行右移位操作(>>>),右移24位,再进行与操作符(&)0xFF,得到的数字即为第一段IP。
将整数值进行右移位操作(>>>),右移16位,再进行与操作符(&)0xFF,得到的数字即为第二段IP。
将整数值进行右移位操作(>>>),右移8位,再进行与操作符(&)0xFF,得到的数字即为第三段IP。
将整数值进行与操作符(&)0xFF,得到的数字即为第四段IP。

二、java代码示例(IPv4Util.java)

package michael.utils; 
import java.net.InetAddress; 
public class IPv4Util { 
 private final static int INADDRSZ = 4; 
 public static byte[] ipToBytesByInet(String ipAddr) { 
  try { 
   return InetAddress.getByName(ipAddr).getAddress(); 
  } catch (Exception e) { 
   throw new IllegalArgumentException(ipAddr + " is invalid IP"); 
  } 
 }JTA实践:Spring+ATOMIKOS 
 public static byte[] ipToBytesByReg(String ipAddr) { 
  byte[] ret = new byte[4]; 
  try { 
   String[] ipArr = ipAddr.split("\\."); 
   ret[0] = (byte) (Integer.parseInt(ipArr[0]) & 0xFF); 
   ret[1] = (byte) (Integer.parseInt(ipArr[1]) & 0xFF); 
   ret[2] = (byte) (Integer.parseInt(ipArr[2]) & 0xFF); 
   ret[3] = (byte) (Integer.parseInt(ipArr[3]) & 0xFF); 
   return ret; 
  } catch (Exception e) { 
   throw new IllegalArgumentException(ipAddr + " is invalid IP"); 
  } 
 } 
 public static String bytesToIp(byte[] bytes) { 
  return new StringBuffer().append(bytes[0] & 0xFF).append('.').append( 
    bytes[1] & 0xFF).append('.').append(bytes[2] & 0xFF) 
    .append('.').append(bytes[3] & 0xFF).toString(); 
 } 
 public static int bytesToInt(byte[] bytes) { 
  int addr = bytes[3] & 0xFF; 
  addr |= ((bytes[2] << 8) & 0xFF00); 
  addr |= ((bytes[1] << 16) & 0xFF0000); 
  addr |= ((bytes[0] << 24) & 0xFF000000); 
  return addr; 
 } 
 public static int ipToInt(String ipAddr) { 
  try { 
   return bytesToInt(ipToBytesByInet(ipAddr)); 
  } catch (Exception e) { 
   throw new IllegalArgumentException(ipAddr + " is invalid IP"); 
  } 
 } 
 public static byte[] intToBytes(int ipInt) { 
  byte[] ipAddr = new byte[INADDRSZ]; 
  ipAddr[0] = (byte) ((ipInt >>> 24) & 0xFF); 
  ipAddr[1] = (byte) ((ipInt >>> 16) & 0xFF); 
  ipAddr[2] = (byte) ((ipInt >>> 8) & 0xFF); 
  ipAddr[3] = (byte) (ipInt & 0xFF); 
  return ipAddr; 
 } 
 public static String intToIp(int ipInt) { 
  return new StringBuilder().append(((ipInt >> 24) & 0xff)).append('.') 
    .append((ipInt >> 16) & 0xff).append('.').append( 
      (ipInt >> 8) & 0xff).append('.').append((ipInt & 0xff)) 
    .toString(); 
 } 
 public static int[] getIPIntScope(String ipAndMask) { 
  String[] ipArr = ipAndMask.split("/"); 
  if (ipArr.length != 2) { 
   throw new IllegalArgumentException("invalid ipAndMask with: " 
     + ipAndMask); 
  } 
  int netMask = Integer.valueOf(ipArr[1].trim()); 
  if (netMask < 0 || netMask > 31) { 
   throw new IllegalArgumentException("invalid ipAndMask with: " 
     + ipAndMask); 
  } 
  int ipInt = IPv4Util.ipToInt(ipArr[0]); 
  int netIP = ipInt & (0xFFFFFFFF << (32 - netMask)); 
  int hostScope = (0xFFFFFFFF >>> netMask); 
  return new int[] { netIP, netIP + hostScope }; 
 } 
 public static String[] getIPAddrScope(String ipAndMask) { 
  int[] ipIntArr = IPv4Util.getIPIntScope(ipAndMask); 
  return new String[] { IPv4Util.intToIp(ipIntArr[0]), 
    IPv4Util.intToIp(ipIntArr[0]) }; 
 } 
 public static int[] getIPIntScope(String ipAddr, String mask) { 
  int ipInt; 
  int netMaskInt = 0, ipcount = 0; 
  try { 
   ipInt = IPv4Util.ipToInt(ipAddr); 
   if (null == mask || "".equals(mask)) { 
    return new int[] { ipInt, ipInt }; 
   } 
   netMaskInt = IPv4Util.ipToInt(mask); 
   ipcount = IPv4Util.ipToInt("255.255.255.255") - netMaskInt; 
   int netIP = ipInt & netMaskInt; 
   int hostScope = netIP + ipcount; 
   return new int[] { netIP, hostScope }; 
  } catch (Exception e) { 
   throw new IllegalArgumentException("invalid ip scope express ip:" 
     + ipAddr + " mask:" + mask); 
  } 
 } 
 public static String[] getIPStrScope(String ipAddr, String mask) { 
  int[] ipIntArr = IPv4Util.getIPIntScope(ipAddr, mask); 
  return new String[] { IPv4Util.intToIp(ipIntArr[0]), 
    IPv4Util.intToIp(ipIntArr[0]) }; 
 } 
 public static void main(String[] args) throws Exception { 
  String ipAddr = "192.168.8.1"; 
  byte[] bytearr = IPv4Util.ipToBytesByInet(ipAddr); 
  StringBuffer byteStr = new StringBuffer(); 
  for (byte b : bytearr) { 
   if (byteStr.length() == 0) { 
    byteStr.append(b); 
   } else { 
    byteStr.append("," + b); 
   } 
  } 
  System.out.println("IP: " + ipAddr + " ByInet --> byte[]: [ " + byteStr 
    + " ]"); 
  bytearr = IPv4Util.ipToBytesByReg(ipAddr); 
  byteStr = new StringBuffer(); 
  for (byte b : bytearr) { 
   if (byteStr.length() == 0) { 
    byteStr.append(b); 
   } else { 
    byteStr.append("," + b); 
   } 
  } 
  System.out.println("IP: " + ipAddr + " ByReg --> byte[]: [ " + byteStr 
    + " ]"); 
  System.out.println("byte[]: " + byteStr + " --> IP: " 
    + IPv4Util.bytesToIp(bytearr)); 
  int ipInt = IPv4Util.ipToInt(ipAddr); 
  System.out.println("IP: " + ipAddr + " --> int: " + ipInt); 
  System.out.println("int: " + ipInt + " --> IP: " 
    + IPv4Util.intToIp(ipInt)); 
  String ipAndMask = "192.168.1.1/24"; 
  int[] ipscope = IPv4Util.getIPIntScope(ipAndMask); 
  System.out.println(ipAndMask + " --> int地址段:[ " + ipscope[0] + "," 
    + ipscope[1] + " ]"); 
  System.out.println(ipAndMask + " --> IP 地址段:[ " 
    + IPv4Util.intToIp(ipscope[0]) + "," 
    + IPv4Util.intToIp(ipscope[1]) + " ]"); 
  String ipAddr1 = "192.168.1.1", ipMask1 = "255.255.255.0"; 
  int[] ipscope1 = IPv4Util.getIPIntScope(ipAddr1, ipMask1); 
  System.out.println(ipAddr1 + " , " + ipMask1 + " --> int地址段 :[ " 
    + ipscope1[0] + "," + ipscope1[1] + " ]"); 
  System.out.println(ipAddr1 + " , " + ipMask1 + " --> IP地址段 :[ " 
    + IPv4Util.intToIp(ipscope1[0]) + "," 
    + IPv4Util.intToIp(ipscope1[1]) + " ]"); 
 } 
}

希望本文所述对大家的java程序设计有所帮助。

相关文章

  • Java后台批量生产echarts图表并保存图片

    Java后台批量生产echarts图表并保存图片

    这篇文章主要介绍了Java后台批量生产echarts图表并保存图片,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Java的优先队列PriorityQueue原理及实例分析

    Java的优先队列PriorityQueue原理及实例分析

    这篇文章主要介绍了Java的优先队列PriorityQueue原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • 迅速学会@ConfigurationProperties的使用操作

    迅速学会@ConfigurationProperties的使用操作

    这篇文章主要介绍了迅速学会@ConfigurationProperties的使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • Java中你真的会用Constructor构造器吗之看完本篇你就真的会了

    Java中你真的会用Constructor构造器吗之看完本篇你就真的会了

    显式初始化要求我们在写程序时就确定初始值,这有时很不方便。我们可以使用构造器(constructor)来初始化对象。构造器可以初始化数据成员,还可以规定特定的操作。这些操作会在创建对象时自动执行。下面文字将对该内容做详细介绍,需要的小伙伴请参考
    2021-09-09
  • SpringBoot3集成Quartz的示例代码

    SpringBoot3集成Quartz的示例代码

    Quartz由Java编写的功能丰富的开源作业调度框架,可以集成到几乎任何Java应用程序中,并且能够创建多个作业调度,在实际的业务中,有很多场景依赖定时任务,比如常见的:订单超时处理,业务识别和预警通知等,本文介绍了SpringBoot3如何集成Quartz
    2023-08-08
  • 浅谈SpringBoot之开启数据库迁移的FlyWay使用

    浅谈SpringBoot之开启数据库迁移的FlyWay使用

    这篇文章主要介绍了浅谈SpringBoot之开启数据库迁移的FlyWay使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • 浅谈java并发之计数器CountDownLatch

    浅谈java并发之计数器CountDownLatch

    CountDownLatch是通过一个计数器来实现的,当我们在new 一个CountDownLatch对象的时候需要带入该计数器值,该值就表示了线程的数量。下面我们来深入了解一下吧
    2019-06-06
  • SpringBoot实现图片防盗链功能

    SpringBoot实现图片防盗链功能

    出于安全考虑,我们需要后端返回的图片只允许在某个网站内展示,不想被爬虫拿到图片地址后被下载,或者,不想浏览器直接访问图片链接,所以本文将给大家介绍SpringBoot实现图片防盗链功能,需要的朋友可以参考下
    2024-04-04
  • SpringBoot+kaptcha实现验证码花式玩法详解

    SpringBoot+kaptcha实现验证码花式玩法详解

    这篇文章主要想和大家聊聊kaptcha的用法,毕竟这个已经有16年历史的玩意还在有人用,说明它的功能还是相当强大的,感兴趣的小伙伴可以了解一下
    2022-05-05
  • 使用spring的restTemplate注意点

    使用spring的restTemplate注意点

    这篇文章主要介绍了使用spring的restTemplate注意点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10

最新评论