民间,
我正在寻找一个Java代码片段,它提供给定IP的下一个地址。
所以getNextIPV4Address("10.1.1.1")
会返回"10.1.1.2"
。
可以完成字符串处理,但最终可能会变得混乱。是否有一种非常正式的方式来做到这一点。
感谢您的时间。
答案 0 :(得分:6)
我正在寻找一个Java代码段,它提供给定IP的下一个地址。
以下是您的代码:
public static String getNextIPV4Address(String ip) {
String[] nums = ip.split("\\.");
int i = (Integer.parseInt(nums[0]) << 24 | Integer.parseInt(nums[2]) << 8
| Integer.parseInt(nums[1]) << 16 | Integer.parseInt(nums[3])) + 1;
// If you wish to skip over .255 addresses.
if ((byte) i == -1) i++;
return String.format("%d.%d.%d.%d", i >>> 24 & 0xFF, i >> 16 & 0xFF,
i >> 8 & 0xFF, i >> 0 & 0xFF);
}
示例输入/输出(ideone.com demonstration):
10.1.1.0 -> 10.1.1.1
10.255.255.255 -> 11.0.0.0
10.0.255.254 -> 10.1.0.0
答案 1 :(得分:4)
IP地址不是“顺序”的,所以我怀疑你会找到一个库来为你做这件事。
答案 2 :(得分:3)
IP地址几乎只是一个32位整数。根据您的存储方式,可以简单地增加此基础值。这可能不会非常可靠,因为你必须考虑子网,不同的地址类等。
正如dty指出的那样,IP地址不是连续的,所以我不认为有任何“正式”方式可以做到这一点。
答案 3 :(得分:2)
这将帮助您入门(添加错误处理,角落案例等):
public static final String nextIpAddress(final String input) {
final String[] tokens = input.split("\\.");
if (tokens.length != 4)
throw new IllegalArgumentException();
for (int i = tokens.length - 1; i >= 0; i--) {
final int item = Integer.parseInt(tokens[i]);
if (item < 255) {
tokens[i] = String.valueOf(item + 1);
for (int j = i + 1; j < 4; j++) {
tokens[j] = "0";
}
break;
}
}
return new StringBuilder()
.append(tokens[0]).append('.')
.append(tokens[1]).append('.')
.append(tokens[2]).append('.')
.append(tokens[3])
.toString();
}
测试用例:
@Test
public void testNextIpAddress() {
assertEquals("1.2.3.5", nextIpAddress("1.2.3.4"));
assertEquals("1.2.4.0", nextIpAddress("1.2.3.255"));
}
答案 4 :(得分:1)
按.
拆分,将最后一个元素转换为int并递增它。检查它的值是否小于254,否则你将赢得一个广播地址。祈祷你总是处理完整的C类子网。
答案 5 :(得分:0)
将字符串拆分为“。”并将4个字符串转换为字节。将所有字节相乘以获得int乘法。增加结果。通过除以整数并在每个字节中存储mod来恢复字节。将字节转换为字符串并连接所有字符串。
答案 6 :(得分:0)
如果使用第三方库是正常的,Guava可以用来获取下一个(或者之后的任何数字)IP地址,如下所示:
InetAddress a = InetAddresses.forString("192.168.1.1");
int i = InetAddresses.coerceToInteger(a);
InetAddress b = InetAddresses.fromInteger(i+1);
String s = InetAddresses.toAddrString(b);
System.out.println(s);