java实现 IP/掩码位 转换 ip段范围

2024-06-05 07:58
文章标签 java 实现 ip 范围 转换 掩码

本文主要是介绍java实现 IP/掩码位 转换 ip段范围,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import java.math.BigDecimal;  
import java.util.ArrayList;  
import java.util.List;  
import java.util.regex.Pattern;  public class IpUtil {  /** * 在main方法里面可以测试下 * 主要功能都在main方法里,需要什么自己找 */  public static void main(String[] args) {  String ip="172.31.0.4";//ip  String mask="31";//位数,如果只知道子网掩码不知道位数的话在参考getMaskMap()方法  //获得起始IP和终止IP的方法(包含网络地址和广播地址)  String startIp=getBeginIpStr(ip, mask);  String endIp=getEndIpStr(ip, mask);  System.out.println("起始IP:" + startIp + "终止IP:" + endIp);  //获得起始IP和终止IP的方法(不包含网络地址和广播地址)  String subStart=startIp.split("\\.")[0]+"."+startIp.split("\\.")[1]+"."+startIp.split("\\.")[2]+".";  String subEnd=endIp.split("\\.")[0]+"."+endIp.split("\\.")[1]+"."+endIp.split("\\.")[2]+".";  startIp=subStart+(Integer.parseInt(startIp.split("\\.")[3])+1);  endIp=subEnd+(Integer.parseInt(endIp.split("\\.")[3])-1);  System.out.println("起始IP:" + startIp + "终止IP:" + endIp);  //判断一个IP是否属于某个网段  boolean flag = isInRange("10.2.0.0", "10.3.0.0/17");  System.out.println(flag);  //根据位数查询IP数量  int ipCount = getIpCount("8");  System.out.println(ipCount);  //判断是否是一个IP  System.out.println(isIP("192.168.1.0"));  //把ip转换为数字(mysql中inet_aton()的实现)  System.out.println(ipToDouble("192.168.1.1"));  //打印IP段所有IP(IP过多会内存溢出)  
//      List<String> list = parseIpMaskRange(ip, mask);  
//      for (String s : list){  
//          System.out.println(s);  
//      }  }  /** * 功能:判断一个IP是不是在一个网段下的 * 格式:isInRange("192.168.8.3", "192.168.9.10/22"); */  public static boolean isInRange(String ip, String cidr) {    String[] ips = ip.split("\\.");    int ipAddr = (Integer.parseInt(ips[0]) << 24)    | (Integer.parseInt(ips[1]) << 16)    | (Integer.parseInt(ips[2]) << 8) | Integer.parseInt(ips[3]);    int type = Integer.parseInt(cidr.replaceAll(".*/", ""));    int mask = 0xFFFFFFFF << (32 - type);    String cidrIp = cidr.replaceAll("/.*", "");    String[] cidrIps = cidrIp.split("\\.");    int cidrIpAddr = (Integer.parseInt(cidrIps[0]) << 24)    | (Integer.parseInt(cidrIps[1]) << 16)    | (Integer.parseInt(cidrIps[2]) << 8)    | Integer.parseInt(cidrIps[3]);    return (ipAddr & mask) == (cidrIpAddr & mask);    }  /** * 功能:根据IP和位数返回该IP网段的所有IP * 格式:parseIpMaskRange("192.192.192.1.", "23") */  public static List<String> parseIpMaskRange(String ip,String mask){  List<String> list=new ArrayList<>();  if ("32".equals(mask)) {  list.add(ip);  }else{  String startIp=getBeginIpStr(ip, mask);  String endIp=getEndIpStr(ip, mask);  if (!"31".equals(mask)) {  String subStart=startIp.split("\\.")[0]+"."+startIp.split("\\.")[1]+"."+startIp.split("\\.")[2]+".";  String subEnd=endIp.split("\\.")[0]+"."+endIp.split("\\.")[1]+"."+endIp.split("\\.")[2]+".";  startIp=subStart+(Integer.parseInt(startIp.split("\\.")[3])+1);  endIp=subEnd+(Integer.parseInt(endIp.split("\\.")[3])-1);  }  list=parseIpRange(startIp, endIp);  }  return list;  }  /** * 功能:根据位数返回IP总数 * 格式:parseIpMaskRange("192.192.192.1", "23") */  public static int getIpCount(String mask) {  return BigDecimal.valueOf(Math.pow(2, 32 - Integer.parseInt(mask))).setScale(0, BigDecimal.ROUND_DOWN).intValue();//IP总数,去小数点  }  /** * 功能:根据位数返回IP总数 * 格式:isIP("192.192.192.1") */  public static boolean isIP(String str) {    String regex = "\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}";    Pattern pattern = Pattern.compile(regex);    return pattern.matcher(str).matches();    }    public static List<String> parseIpRange(String ipfrom, String ipto) {  List<String> ips = new ArrayList<String>();  String[] ipfromd = ipfrom.split("\\.");  String[] iptod = ipto.split("\\.");  int[] int_ipf = new int[4];  int[] int_ipt = new int[4];  for (int i = 0; i < 4; i++) {  int_ipf[i] = Integer.parseInt(ipfromd[i]);  int_ipt[i] = Integer.parseInt(iptod[i]);  }  for (int A = int_ipf[0]; A <= int_ipt[0]; A++) {  for (int B = (A == int_ipf[0] ? int_ipf[1] : 0); B <= (A == int_ipt[0] ? int_ipt[1]  : 255); B++) {  for (int C = (B == int_ipf[1] ? int_ipf[2] : 0); C <= (B == int_ipt[1] ? int_ipt[2]  : 255); C++) {  for (int D = (C == int_ipf[2] ? int_ipf[3] : 0); D <= (C == int_ipt[2] ? int_ipt[3]  : 255); D++) {  ips.add(A + "." + B + "." + C + "." + D);  }  }  }  }  return ips;  }  /** * 把long类型的Ip转为一般Ip类型:xx.xx.xx.xx * * @param ip * @return */  public static String getIpFromLong(Long ip)  {  String s1 = String.valueOf((ip & 4278190080L) / 16777216L);  String s2 = String.valueOf((ip & 16711680L) / 65536L);  String s3 = String.valueOf((ip & 65280L) / 256L);  String s4 = String.valueOf(ip & 255L);  return s1 + "." + s2 + "." + s3 + "." + s4;  }  /** * 把xx.xx.xx.xx类型的转为long类型的 * * @param ip * @return */  public static Long getIpFromString(String ip)  {  Long ipLong = 0L;  String ipTemp = ip;  ipLong = ipLong * 256  + Long.parseLong(ipTemp.substring(0, ipTemp.indexOf('.')));  ipTemp = ipTemp.substring(ipTemp.indexOf('.') + 1, ipTemp.length());  ipLong = ipLong * 256  + Long.parseLong(ipTemp.substring(0, ipTemp.indexOf('.')));  ipTemp = ipTemp.substring(ipTemp.indexOf(".") + 1, ipTemp.length());  ipLong = ipLong * 256  + Long.parseLong(ipTemp.substring(0, ipTemp.indexOf('.')));  ipTemp = ipTemp.substring(ipTemp.indexOf('.') + 1, ipTemp.length());  ipLong = ipLong * 256 + Long.parseLong(ipTemp);  return ipLong;  }  /** * 根据掩码位获取掩码 * * @param maskBit *            掩码位数,如"28"、"30" * @return */  public static String getMaskByMaskBit(String maskBit)  {  return "".equals(maskBit) ? "error, maskBit is null !" : getMaskMap(maskBit);  }  /** * 根据 ip/掩码位 计算IP段的起始IP 如 IP串 218.240.38.69/30 * * @param ip *            给定的IP,如218.240.38.69 * @param maskBit *            给定的掩码位,如30 * @return 起始IP的字符串表示 */  public static String getBeginIpStr(String ip, String maskBit)  {  return getIpFromLong(getBeginIpLong(ip, maskBit));  }  /** * 根据 ip/掩码位 计算IP段的起始IP 如 IP串 218.240.38.69/30 * * @param ip *            给定的IP,如218.240.38.69 * @param maskBit *            给定的掩码位,如30 * @return 起始IP的长整型表示 */  public static Long getBeginIpLong(String ip, String maskBit)  {  return getIpFromString(ip) & getIpFromString(getMaskByMaskBit(maskBit));  }  /** * 根据 ip/掩码位 计算IP段的终止IP 如 IP串 218.240.38.69/30 * * @param ip *            给定的IP,如218.240.38.69 * @param maskBit *            给定的掩码位,如30 * @return 终止IP的字符串表示 */  public static String getEndIpStr(String ip, String maskBit)  {  return getIpFromLong(getEndIpLong(ip, maskBit));  }  /** * 根据 ip/掩码位 计算IP段的终止IP 如 IP串 218.240.38.69/30 * * @param ip *            给定的IP,如218.240.38.69 * @param maskBit *            给定的掩码位,如30 * @return 终止IP的长整型表示 */  public static Long getEndIpLong(String ip, String maskBit)  {  return getBeginIpLong(ip, maskBit)  + ~getIpFromString(getMaskByMaskBit(maskBit));  }  /** * 根据子网掩码转换为掩码位 如 255.255.255.252转换为掩码位 为 30 * * @param netmarks * @return */  public static int getNetMask(String netmarks)  {  StringBuilder sbf;  String str;  int inetmask = 0;  int count = 0;  String[] ipList = netmarks.split("\\.");  for (int n = 0; n < ipList.length; n++)  {  sbf = toBin(Integer.parseInt(ipList[n]));  str = sbf.reverse().toString();  count = 0;  for (int i = 0; i < str.length(); i++)  {  i = str.indexOf('1', i);  if (i == -1)  {  break;  }  count++;  }  inetmask += count;  }  return inetmask;  }  /** * 计算子网大小 * * @param netmask *            掩码位 * @return */  public static int getPoolMax(int maskBit)  {  if (maskBit <= 0 || maskBit >= 32)  {  return 0;  }  return (int) Math.pow(2, 32 - maskBit) - 2;  }  private static StringBuilder toBin(int x)  {  StringBuilder result = new StringBuilder();  result.append(x % 2);  x /= 2;  while (x > 0)  {  result.append(x % 2);  x /= 2;  }  return result;  }  public static String getMaskMap(String maskBit) {  if ("1".equals(maskBit)) return "128.0.0.0";  if ("2".equals(maskBit)) return "192.0.0.0";  if ("3".equals(maskBit)) return "224.0.0.0";  if ("4".equals(maskBit)) return "240.0.0.0";  if ("5".equals(maskBit)) return "248.0.0.0";  if ("6".equals(maskBit)) return "252.0.0.0";  if ("7".equals(maskBit)) return "254.0.0.0";  if ("8".equals(maskBit)) return "255.0.0.0";  if ("9".equals(maskBit)) return "255.128.0.0";  if ("10".equals(maskBit)) return "255.192.0.0";  if ("11".equals(maskBit)) return "255.224.0.0";  if ("12".equals(maskBit)) return "255.240.0.0";  if ("13".equals(maskBit)) return "255.248.0.0";  if ("14".equals(maskBit)) return "255.252.0.0";  if ("15".equals(maskBit)) return "255.254.0.0";  if ("16".equals(maskBit)) return "255.255.0.0";  if ("17".equals(maskBit)) return "255.255.128.0";  if ("18".equals(maskBit)) return "255.255.192.0";  if ("19".equals(maskBit)) return "255.255.224.0";  if ("20".equals(maskBit)) return "255.255.240.0";  if ("21".equals(maskBit)) return "255.255.248.0";  if ("22".equals(maskBit)) return "255.255.252.0";  if ("23".equals(maskBit)) return "255.255.254.0";  if ("24".equals(maskBit)) return "255.255.255.0";  if ("25".equals(maskBit)) return "255.255.255.128";  if ("26".equals(maskBit)) return "255.255.255.192";  if ("27".equals(maskBit)) return "255.255.255.224";  if ("28".equals(maskBit)) return "255.255.255.240";  if ("29".equals(maskBit)) return "255.255.255.248";  if ("30".equals(maskBit)) return "255.255.255.252";  if ("31".equals(maskBit)) return "255.255.255.254";  if ("32".equals(maskBit)) return "255.255.255.255";  return "-1";  }  public static double ipToDouble(String ip) {  String[] arr = ip.split("\\.");  double d1 = Double.parseDouble(arr[0]);  double d2 = Double.parseDouble(arr[1]);  double d3 = Double.parseDouble(arr[2]);  double d4 = Double.parseDouble(arr[3]);  return d1 * Math.pow(256, 3) + d2 * Math.pow(256, 2) + d3 * 256 + d4;  }  
}  

 

这篇关于java实现 IP/掩码位 转换 ip段范围的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1032509

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听