注意在java中Integer是有符号的,最大值为2147483647,所以需要Long来盛放转换后的整数;位移运算优先级低于加法运算,位移处加了括号:
public static Long getIpNum(final String ip) {
Long ipNum = 0L;
final String[] ipStr = ip.trim().split("\\.");
for (final String str : ipStr) {
ipNum = (ipNum << 8) + Integer.parseInt(str);
}
return ipNum;
}
同时mysql也提供了相关函数,可以方便进行转换:select INET_ATON('255.255.255.255');-- 4294967295
select INET_NTOA(4294967295);-- 255.255.255.255
本文代码出发点是考虑包括两个极端的情况,即0.0.0.0~255.255.255.255,所以代码中使用Long类型,Long类型占用8字节,而数据库支持无符号整型,4字节就可以保存。由整数转为ipv4地址可以直接使用mysql的函数,也可以在代码中使用右移操作取出每个字节所代表的的整数,然后拼接"."。