java ip段 匹配_IP段匹配

本文介绍了如何使用Java编写一个工具类`IpUtil`,该类包含了一个`ipExistsInRange`方法,用于判断一个IP地址是否在一个指定的IP段范围内。通过将IP地址转换为整数进行比较,实现了IP段的有效匹配。示例代码展示了如何检查IP地址`10.10.10.116`是否属于`10.10.1.00-10.10.255.255`这个IP段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[java]代码库public class IpUtil {

/*验证IP是否属于某个IP段

*

* ipSection IP段(以'-'分隔)

* ip 所验证的IP号码

*

*/

public static boolean ipExistsInRange(String ip,String ipSection) {

ipSection = ipSection.trim();

ip = ip.trim();

int idx = ipSection.indexOf('-');

String beginIP = ipSection.substring(0, idx);

String endIP = ipSection.substring(idx + 1);

return getIp2long(beginIP)<=getIp2long(ip) &&getIp2long(ip)<=getIp2long(endIP);

}

public static long getIp2long(String ip) {

ip = ip.trim();

String[] ips = ip.split("\\.");

long ip2long = 0L;

for (int i = 0; i < 4; ++i) {

ip2long = ip2long << 8 | Integer.parseInt(ips[i]);

}

return ip2long;

}

public static long getIp2long2(String ip) {

ip = ip.trim();

String[] ips = ip.split("\\.");

long ip1 = Integer.parseInt(ips[0]);

long ip2 = Integer.parseInt(ips[1]);

long ip3 = Integer.parseInt(ips[2]);

long ip4 = Integer.parseInt(ips[3]);

long ip2long =1L* ip1 * 256 * 256 * 256 + ip2 * 256 * 256 + ip3 * 256 + ip4;

return ip2long;

}

public static void main(String[] args){

//10.10.10.116 是否属于固定格式的IP段10.10.1.00-10.10.255.255

String ip="10.10.10.116";

String ipSection="10.10.1.00-10.10.255.255";

boolean exists=ipExistsInRange(ip,ipSection);

System.out.println(exists);

System.out.println(getIp2long(ip));

System.out.println(getIp2long2(ip));

}

}

694748ed64b9390909c0d88230893790.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值