一、將ip地址轉成long數值
將IP地址轉化成整數的方法如下:
1、通過String的split方法按.分隔得到4個長度的數組
2、通過左移位操作(<<)給每一段的數字加權,第一段的權為2的24次方,第二段的權為2的16次方,第三段的權為2的8次方,最后一段的權為1
二、將數值轉換為ip地址
將十進制整數形式轉換成127.0.0.1形式的ip地址
將整數形式的IP地址轉化成字符串的方法如下:
1、將整數值進行右移位操作(>>>),右移24位,右移時高位補0,得到的數字即為第一段IP。
2、通過與操作符(&)將整數值的高8位設為0,再右移16位,得到的數字即為第二段IP。
3、通過與操作符吧整數值的高16位設為0,再右移8位,得到的數字即為第三段IP。
4、通過與操作符吧整數值的高24位設為0,得到的數字即為第四段IP。
三、代碼具體的實現
public class IPUtil {
/**
* ip地址轉成long型數字
* 將IP地址轉化成整數的方法如下:
* 1、通過String的split方法按.分隔得到4個長度的數組
* 2、通過左移位操作(<<)給每一段的數字加權,第一段的權為2的24次方,第二段的權為2的16次方,第三段的權為2的8次方,最后一段的權為1
* @param strIp
* @return
*/
public static long ipToLong(String strIp) {
String[]ip = strIp.split("\\.");
return (Long.parseLong(ip[0]) << 24) + (Long.parseLong(ip[1]) << 16) + (Long.parseLong(ip[2]) << 8) + Long.parseLong(ip[3]);
}
/**
* 將十進制整數形式轉換成127.0.0.1形式的ip地址
* 將整數形式的IP地址轉化成字符串的方法如下:
* 1、將整數值進行右移位操作(>>>),右移24位,右移時高位補0,得到的數字即為第一段IP。
* 2、通過與操作符(&)將整數值的高8位設為0,再右移16位,得到的數字即為第二段IP。
* 3、通過與操作符吧整數值的高16位設為0,再右移8位,得到的數字即為第三段IP。
* 4、通過與操作符吧整數值的高24位設為0,得到的數字即為第四段IP。
* @param longIp
* @return
*/
public static String longToIP(long longIp) {
StringBuffer sb = new StringBuffer("");
// 直接右移24位
sb.append(String.valueOf((longIp >>> 24)));
sb.append(".");
// 將高8位置0,然后右移16位
sb.append(String.valueOf((longIp & 0x00FFFFFF) >>> 16));
sb.append(".");
// 將高16位置0,然后右移8位
sb.append(String.valueOf((longIp & 0x0000FFFF) >>> 8));
sb.append(".");
// 將高24位置0
sb.append(String.valueOf((longIp & 0x000000FF)));
return sb.toString();
}
public static void main(String[] args) {
System.out.println(ipToLong("219.239.110.138"));
System.out.println(longToIP(18537472));
}
}
或者:
package hiveTest;
import org.apache.hadoop.hive.ql.exec.UDF;
public class IpConcat extends UDF{
public Boolean evaluate(String ip, String cidr){
return isInRange(ip, cidr);
}
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網段轉換為對應的數字范圍,暫時不支持ipv6
public class AddressConvert extends UDF { #繼承UDF,編寫hive的自定義函數
public Boolean evaluate(String ip, String cidr){ #需要實現的方法
return isInRange(ip, cidr);
}
private Boolean isInRange(String ip, String cidr) {
String[] split = cidr.split("\\/");
String[] ips = split[0].split("\\.");
long minValue = 0L;
long maxValue = 0L;
if (split.length == 1) {
long intIp = Long.parseLong(ips[0]) << 24
| Long.parseLong(ips[1]) << 16
| Long.parseLong(ips[2]) << 8
| Long.parseLong(ips[3]);
}
else if (split.length == 2) {
int flag = Integer.parseInt(split[1]) >> 3;
switch (flag) {
case 1:
minValue = Long.parseLong(ips[0]) << 24
| Long.parseLong(ips[1]) << 16
| Long.parseLong(ips[2]) << 8
| Long.parseLong("1");
maxValue = Long.parseLong(ips[0]) << 24
| Long.parseLong(ips[1]) << 16
| Long.parseLong(ips[2]) << 8
| Long.parseLong("254");
break;
case 2:
minValue = Long.parseLong(ips[0]) << 24
| Long.parseLong(ips[1]) << 16
| Long.parseLong("0") << 8
| Long.parseLong("1");
maxValue = Long.parseLong(ips[0]) << 24
| Long.parseLong(ips[1]) << 16
| Long.parseLong("255") << 8
| Long.parseLong("254");
break;
case 3:
minValue = Long.parseLong(ips[0]) << 24
| Long.parseLong("0") << 16
| Long.parseLong("0") << 8
| Long.parseLong("1");
maxValue = Long.parseLong(ips[0]) << 24
| Long.parseLong("255") << 16
| Long.parseLong("255") << 8
| Long.parseLong("254");
break;
}
}
// 源ip轉換
Long intSip = Long.parseLong(ip);
// String[] sip = ip.split("\\.");
// Long intSip = Long.parseLong(sip[0]) << 24
// | Long.parseLong(sip[1]) << 16
// | Long.parseLong(sip[2]) << 8
// | Long.parseLong(sip[3]);
if (minValue <= intSip && intSip <= maxValue) {
return true;
}else {
return false;
}
}
}