判断两个IP大小及是否在同一个网段中


java ip 网段 ip地址


功能点 



  • 判断某个IP地址是否合法
  • 判断两个IP地址是否在同一个网段中
  • 判断两个IP地址的大小关系



知识准备







基本原理






IP地址范围



255.255.255.255,包括了mask地址。





IP地址划分



  • A类地址:1.0.0.1~126.255.255.254
  • B类地址:128.0.0.1~191.255.255.254
  • C类地址:192.168.0.0~192.168.255.255
  • D类地址:224.0.0.1~239.255.255.254
  • E类地址:240.0.0.1~255.255.255.254



判断两个IP地址是否是同一个网段中



     要判断两个IP地址是不是在同一个网段,就将它们的IP地址分别与子网掩码做与运算,得到的结果一网络号,如果网络号相同,就在同一子网,否则,不在同一子网。


     例:假定选择了子网掩码255.255.254.0,现在分别将上述两个IP地址分别与掩码做与运算,如下图所示:

211.95.165.24 11010011 01011111 10100101 00011000

255.255.254.0 11111111 11111111 111111110 00000000

与的结果是: 11010011 01011111 10100100 00000000


211.95.164.78 11010011 01011111 10100100 01001110

255.255.254.0 11111111 11111111 111111110 00000000

与的结果是: 11010011 01011111 10100100 00000000



     可以看出,得到的结果(这个结果就是网络地址)都是一样的,因此可以判断这两个IP地址在同一个子网。




     如果没有进行子网划分,A类网络的子网掩码为255.0.0.0,B类网络的子网掩码为255.255.0.0,C类网络的子网掩码为255.255.255.0,缺省情况子网掩码为255.255.255.0



实现



   以Java语言实现,主要针对IPv4地址。



      代码实现如下(包括注释):



[java]  view plain copy


1. package org.slive.net;  
2.   
3. import java.net.UnknownHostException;  
4. import java.util.regex.Pattern;  
5.   
6. /**
7. * <pre>
8. * IP地址范围:
9. * 0.0.0.0~255.255.255.255,包括了mask地址。
10. *
11. * IP地址划分:
12. * A类地址:1.0.0.1~126.255.255.254
13. * B类地址:128.0.0.1~191.255.255.254
14. * C类地址:192.168.0.0~192.168.255.255
15. * D类地址:224.0.0.1~239.255.255.254
16. * E类地址:240.0.0.1~255.255.255.254
17. *
18. * 如何判断两个IP地址是否是同一个网段中:
19. * 要判断两个IP地址是不是在同一个网段,就将它们的IP地址分别与子网掩码做与运算,得到的结果一网络号,如果网络号相同,就在同一子网,否则,不在同一子网。
20. * 例:假定选择了子网掩码255.255.254.0,现在分别将上述两个IP地址分别与掩码做与运算,如下图所示:
21. * 211.95.165.24 11010011 01011111 10100101 00011000
22. * 255.255.254.0 11111111 11111111 111111110 00000000
23. * 与的结果是: 11010011 01011111 10100100 00000000
24. *
25. * 211.95.164.78 11010011 01011111 10100100 01001110
26. * 255.255.254.0 11111111 11111111 111111110 00000000
27. * 与的结果是: 11010011 01011111 10100100 00000000
28. * 可以看出,得到的结果(这个结果就是网络地址)都是一样的,因此可以判断这两个IP地址在同一个子网。
29. *
30. * 如果没有进行子网划分,A类网络的子网掩码为255.0.0.0,B类网络的子网掩码为255.255.0.0,C类网络的子网掩码为255.255.255.0,缺省情况子网掩码为255.255.255.0
31. *
32. * @author Slive
33. */  
34. public class IpV4Util  
35. {  
36. // IpV4的正则表达式,用于判断IpV4地址是否合法  
37. private static final String IPV4_REGEX = "((\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])(\\.(\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])){3})";  
38.       
39. // 系统子网掩码,它与ip组成一个地址  
40. private int mask;  
41.       
42. // 1代表A类,2代表B类,3代表C类;4代表其它类型  
43. public final static int IP_A_TYPE = 1;  
44. public final static int IP_B_TYPE = 2;  
45. public final static int IP_C_TYPE = 3;  
46. public final static int IP_OTHER_TYPE = 4;  
47.       
48. // A类地址范围:1.0.0.1---126.255.255.254  
49. private static int[] IpATypeRange;  
50. // B类地址范围:128.0.0.1---191.255.255.254  
51. private static int[] IpBTypeRange;  
52. // C类地址范围:192.168.0.0~192.168.255.255  
53. private static int[] IpCTypeRange;  
54.       
55. // A,B,C类地址的默认mask  
56. private static int DefaultIpAMask;  
57. private static int DefaultIpBMask;  
58. private static int DefaultIpCMask;  
59.       
60. // 初始化  
61. static  
62.      {  
63. new int[2];  
64. 0] = getIpV4Value("1.0.0.1");  
65. 1] = getIpV4Value("126.255.255.254");  
66.            
67. new int[2];  
68. 0] = getIpV4Value("128.0.0.1");  
69. 1] = getIpV4Value("191.255.255.254");  
70.            
71. new int[2];  
72. 0] = getIpV4Value("192.168.0.0");  
73. 1] = getIpV4Value("192.168.255.255");  
74.            
75. "255.0.0.0");  
76. "255.255.0.0");  
77. "255.255.255.0");  
78.      }  
79.       
80. /**
81.      * 默认255.255.255.0
82.      */  
83. public IpV4Util()  
84.      {  
85. "255.255.255.0");  
86.      }  
87.       
88. /**
89.      * @param mask 任意的如"255.255.254.0"等格式,如果格式不合法,抛出UnknownError异常错误
90.      */  
91. public IpV4Util(String masks)  
92.      {  
93.           mask = getIpV4Value(masks);  
94. if(mask == 0)  
95.           {  
96. throw new UnknownError();  
97.           }  
98.      }  
99.       
100. public int getMask()  
101.      {  
102. return mask;  
103.      }  
104.       
105. /**
106.      * 比较两个ip地址是否在同一个网段中,如果两个都是合法地址,两个都是非法地址时,可以正常比较;
107.      * 如果有其一不是合法地址则返回false;
108.      * 注意此处的ip地址指的是如“192.168.1.1”地址,并不包括mask
109.      * @return
110.      */  
111. public boolean checkSameSegment(String ip1,String ip2)  
112.      {  
113. return checkSameSegment(ip1,ip2,mask);  
114.      }  
115.       
116. /**
117.      * 比较两个ip地址是否在同一个网段中,如果两个都是合法地址,两个都是非法地址时,可以正常比较;
118.      * 如果有其一不是合法地址则返回false;
119.      * 注意此处的ip地址指的是如“192.168.1.1”地址
120.      * @return
121.      */  
122. public static boolean checkSameSegment(String ip1,String ip2, int mask)  
123.      {  
124. // 判断IPV4是否合法  
125. if(!ipV4Validate(ip1))  
126.           {  
127. return false;  
128.           }  
129. if(!ipV4Validate(ip2))  
130.           {  
131. return false;  
132.           }  
133. int ipValue1 = getIpV4Value(ip1);  
134. int ipValue2 = getIpV4Value(ip2);  
135. return (mask & ipValue1) == (mask & ipValue2);  
136.      }  
137.       
138. /**
139.      * 比较两个ip地址是否在同一个网段中,如果两个都是合法地址,两个都是非法地址时,可以正常比较;
140.      * 如果有其一不是合法地址则返回false;
141.      * 注意此处的ip地址指的是如“192.168.1.1”地址
142.      * @return
143.      */  
144. public static boolean checkSameSegmentByDefault(String ip1,String ip2)  
145.      {  
146. int mask = getDefaultMaskValue(ip1);     // 获取默认的Mask  
147. return checkSameSegment(ip1,ip2,mask);  
148.      }  
149.       
150. /**
151.      * 获取ip值与mask值与的结果
152.      * @param ipV4
153.      * @return  32bit值
154.      */  
155. public int getSegmentValue(String ipV4)  
156.      {  
157. int ipValue = getIpV4Value(ipV4);  
158. return (mask & ipValue);  
159.      }  
160.       
161. /**
162.      * 获取ip值与mask值与的结果
163.      * @param ipV4
164.      * @return  32bit值
165.      */  
166. public static int getSegmentValue(String ip, int mask)  
167.      {  
168. int ipValue = getIpV4Value(ip);  
169. return (mask & ipValue);  
170.      }  
171.       
172. /**
173.      * 判断ipV4或者mask地址是否合法,通过正则表达式方式进行判断
174.      * @param ipv4
175.      */  
176. public static boolean ipV4Validate(String ipv4)  
177.     {  
178. return ipv4Validate(ipv4,IPV4_REGEX);  
179.     }  
180.      
181. private static boolean ipv4Validate(String addr,String regex)  
182.     {  
183. if(addr == null)  
184.           {  
185. return false;  
186.          }  
187. else  
188.          {  
189. return Pattern.matches(regex, addr.trim());  
190.          }  
191.      }  
192.      
193. /**
194.      * 比较两个ip地址,如果两个都是合法地址,则1代表ip1大于ip2,-1代表ip1小于ip2,0代表相等;
195.      * 如果有其一不是合法地址,如ip2不是合法地址,则ip1大于ip2,返回1,反之返回-1;两个都是非法地址时,则返回0;
196.      * 注意此处的ip地址指的是如“192.168.1.1”地址,并不包括mask
197.      * @return
198.      */  
199. public static int compareIpV4s(String ip1,String ip2)  
200.      {  
201. int result = 0;  
202. int ipValue1 = getIpV4Value(ip1);     // 获取ip1的32bit值  
203. int ipValue2 = getIpV4Value(ip2); // 获取ip2的32bit值  
204. if(ipValue1 > ipValue2)  
205.           {  
206. 1;  
207.           }  
208. else if(ipValue1 <= ipValue2)  
209.           {  
210. 1;  
211.           }  
212. return result;  
213.      }  
214.       
215. /**
216.      * 检测ipV4 的类型,包括A类,B类,C类,其它(C,D和广播)类等
217.      * @param ipV4
218.      * @return     返回1代表A类,返回2代表B类,返回3代表C类;返回4代表D类
219.      */  
220. public static int checkIpV4Type(String ipV4)  
221.      {  
222. int inValue = getIpV4Value(ipV4);  
223. if(inValue >= IpCTypeRange[0] && inValue <= IpCTypeRange[1])  
224.           {  
225. return IP_C_TYPE;  
226.           }  
227. else if(inValue >= IpBTypeRange[0] && inValue <= IpBTypeRange[1])  
228.           {  
229. return IP_B_TYPE;  
230.           }  
231. else if(inValue >= IpATypeRange[0] && inValue <= IpATypeRange[1])  
232.           {  
233. return IP_A_TYPE;  
234.           }  
235. return IP_OTHER_TYPE;  
236.      }  
237.       
238. /**
239.      * 获取默认mask值,如果IpV4是A类地址,则返回{@linkplain #DefaultIpAMask},
240.      * 如果IpV4是B类地址,则返回{@linkplain #DefaultIpBMask},以此类推
241.      * @param anyIpV4 任何合法的IpV4
242.      * @return mask 32bit值
243.      */  
244. public static int getDefaultMaskValue(String anyIpV4)  
245.      {  
246. int checkIpType = checkIpV4Type(anyIpV4);  
247. int maskValue = 0;  
248. switch (checkIpType)  
249.           {  
250. case IP_C_TYPE:  
251.                     maskValue = DefaultIpCMask;  
252. break;  
253. case IP_B_TYPE:  
254.                     maskValue = DefaultIpBMask;  
255. break;  
256. case IP_A_TYPE:  
257.                     maskValue = DefaultIpAMask;  
258. break;  
259. default:  
260.                     maskValue = DefaultIpCMask;  
261.           }  
262. return maskValue;  
263.      }  
264.       
265. /**
266.      * 获取默认mask地址,A类地址对应255.0.0.0,B类地址对应255.255.0.0,
267.      * C类及其它对应255.255.255.0
268.      * @param anyIp
269.      * @return mask 字符串表示
270.      */  
271. public static String getDefaultMaskStr(String anyIp)  
272.      {  
273. return trans2IpStr(getDefaultMaskValue(anyIp));  
274.      }  
275.       
276. /**
277.      * 将ip 32bit值转换为如“192.168.0.1”等格式的字符串
278.      * @param ipValue 32bit值
279.      * @return
280.      */  
281. public static String trans2IpStr(int ipValue)  
282.      {  
283. // 保证每一位地址都是正整数  
284. return ((ipValue >> 24) & 0xff) + "." + ((ipValue >> 16) & 0xff) + "." + ((ipValue >> 8) & 0xff) + "." + (ipValue & 0xff);  
285.      }  
286.       
287. /**
288.      * 将ip byte数组值转换为如“192.168.0.1”等格式的字符串
289.      * @param ipBytes 32bit值
290.      * @return
291.      */  
292. public static String trans2IpV4Str(byte[] ipBytes)  
293.     {  
294. // 保证每一位地址都是正整数  
295. return (ipBytes[0] & 0xff) + "." + (ipBytes[1] & 0xff) + "." + (ipBytes[2] & 0xff) + "." + (ipBytes[3] & 0xff);  
296.     }  
297.   
298. public static int getIpV4Value(String ipOrMask)  
299.      {  
300. byte[] addr = getIpV4Bytes(ipOrMask);  
301. int address1  = addr[3] & 0xFF;  
302. 2] << 8) & 0xFF00);  
303. 1] << 16) & 0xFF0000);  
304. 0] << 24) & 0xFF000000);  
305. return address1;  
306.      }  
307.   
308. public static byte[] getIpV4Bytes(String ipOrMask)  
309.      {  
310. try  
311.           {  
312. "\\.");  
313. int length = addrs.length;  
314. byte[] addr = new byte[length];  
315. for (int index = 0; index < length; index++)  
316.                {  
317. byte) (Integer.parseInt(addrs[index]) & 0xff);  
318.                }  
319. return addr;  
320.           }  
321. catch (Exception e)  
322.           {  
323.           }  
324. return new byte[4];  
325.      }  
326. }



应用



[java]  
     view plain 
     copy 
     
 
     
 
   
1. public static void main(String[] args) throws UnknownHostException  
2.     {  
3. // 判断ip两个地址的大小关系  
4. "10.8.9.116";  
5. "10.8.9.10";  
6. "ip1 大于 ip2? " + (compareIpV4s (ip1, ip2) > 0));  
7.   
8. "10.8.8.116";  
9. "10.10.9.10";  
10.             
11. "ip3 大于 ip4? " + (compareIpV4s (ip3, ip4) > 0));  
12.             
13. // 判断ip两个地址是否是同一个网段  
14. int mask1 = getIpV4Value( "255.255.255.0");  
15. int mask2 = getIpV4Value( "255.255.0.0");  
16.             
17. "ip1和ip2在同一个网段中? " + (checkSameSegment(ip1, ip2, mask1)));  
18.             
19. "ip3和ip4在同一个网段中 ?" + (checkSameSegment(ip3, ip4, mask2)));  
20.             
21. // 判断ip5是否在ip1和ip2范围中  
22. "10.8.8.8";  
23. // 假设ip1和ip2在同一个网段中,并且ip1为起始地址,ip2为结束地址,ip1<=1  
24. // 比较ip1与ip5是否在同一个网段中  
25. if(checkSameSegment(ip1, ip5, mask1))  
26.                 {  
27. // 判断ip5是否在ip1和ip2范围中  
28. if(((compareIpV4s(ip5, ip1)) >= 0) && (compareIpV4s(ip5, ip2) <= 0))  
29.                       {  
30. "ip5 在ip1-ip2范围内" );  
31.                       }  
32. else if ((compareIpV4s(ip5, ip1)) < 0)  
33.                       {  
34. "ip5 不在ip1-ip2范围内,因为ip5小于ip1" );  
35.                       }  
36. else  
37.                       {  
38. "ip5 不在ip1-ip2范围内,因为ip5大于ip2" );  
39.                       }  
40.                 }  
41. else  
42.                 {  
43. "ip5 不在ip1-ip2范围内,因为ip5不在ip1的网段中" );  
44.                 }  
45.     }

功能点 



  • 判断某个IP地址是否合法
  • 判断两个IP地址是否在同一个网段中
  • 判断两个IP地址的大小关系



知识准备







基本原理






IP地址范围



255.255.255.255,包括了mask地址。





IP地址划分



  • A类地址:1.0.0.1~126.255.255.254
  • B类地址:128.0.0.1~191.255.255.254
  • C类地址:192.168.0.0~192.168.255.255
  • D类地址:224.0.0.1~239.255.255.254
  • E类地址:240.0.0.1~255.255.255.254



判断两个IP地址是否是同一个网段中



     要判断两个IP地址是不是在同一个网段,就将它们的IP地址分别与子网掩码做与运算,得到的结果一网络号,如果网络号相同,就在同一子网,否则,不在同一子网。


     例:假定选择了子网掩码255.255.254.0,现在分别将上述两个IP地址分别与掩码做与运算,如下图所示:

211.95.165.24 11010011 01011111 10100101 00011000

255.255.254.0 11111111 11111111 111111110 00000000

与的结果是: 11010011 01011111 10100100 00000000


211.95.164.78 11010011 01011111 10100100 01001110

255.255.254.0 11111111 11111111 111111110 00000000

与的结果是: 11010011 01011111 10100100 00000000



     可以看出,得到的结果(这个结果就是网络地址)都是一样的,因此可以判断这两个IP地址在同一个子网。




     如果没有进行子网划分,A类网络的子网掩码为255.0.0.0,B类网络的子网掩码为255.255.0.0,C类网络的子网掩码为255.255.255.0,缺省情况子网掩码为255.255.255.0



实现



   以Java语言实现,主要针对IPv4地址。



      代码实现如下(包括注释):


[java]  
     view plain 
     copy 
     
 
     
 
   
1. package org.slive.net;  
2.   
3. import java.net.UnknownHostException;  
4. import java.util.regex.Pattern;  
5.   
6. /**
7. * <pre>
8. * IP地址范围:
9. * 0.0.0.0~255.255.255.255,包括了mask地址。
10. *
11. * IP地址划分:
12. * A类地址:1.0.0.1~126.255.255.254
13. * B类地址:128.0.0.1~191.255.255.254
14. * C类地址:192.168.0.0~192.168.255.255
15. * D类地址:224.0.0.1~239.255.255.254
16. * E类地址:240.0.0.1~255.255.255.254
17. *
18. * 如何判断两个IP地址是否是同一个网段中:
19. * 要判断两个IP地址是不是在同一个网段,就将它们的IP地址分别与子网掩码做与运算,得到的结果一网络号,如果网络号相同,就在同一子网,否则,不在同一子网。
20. * 例:假定选择了子网掩码255.255.254.0,现在分别将上述两个IP地址分别与掩码做与运算,如下图所示:
21. * 211.95.165.24 11010011 01011111 10100101 00011000
22. * 255.255.254.0 11111111 11111111 111111110 00000000
23. * 与的结果是: 11010011 01011111 10100100 00000000
24. *
25. * 211.95.164.78 11010011 01011111 10100100 01001110
26. * 255.255.254.0 11111111 11111111 111111110 00000000
27. * 与的结果是: 11010011 01011111 10100100 00000000
28. * 可以看出,得到的结果(这个结果就是网络地址)都是一样的,因此可以判断这两个IP地址在同一个子网。
29. *
30. * 如果没有进行子网划分,A类网络的子网掩码为255.0.0.0,B类网络的子网掩码为255.255.0.0,C类网络的子网掩码为255.255.255.0,缺省情况子网掩码为255.255.255.0
31. *
32. * @author Slive
33. */  
34. public class IpV4Util  
35. {  
36. // IpV4的正则表达式,用于判断IpV4地址是否合法  
37. private static final String IPV4_REGEX = "((\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])(\\.(\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])){3})";  
38.       
39. // 系统子网掩码,它与ip组成一个地址  
40. private int mask;  
41.       
42. // 1代表A类,2代表B类,3代表C类;4代表其它类型  
43. public final static int IP_A_TYPE = 1;  
44. public final static int IP_B_TYPE = 2;  
45. public final static int IP_C_TYPE = 3;  
46. public final static int IP_OTHER_TYPE = 4;  
47.       
48. // A类地址范围:1.0.0.1---126.255.255.254  
49. private static int[] IpATypeRange;  
50. // B类地址范围:128.0.0.1---191.255.255.254  
51. private static int[] IpBTypeRange;  
52. // C类地址范围:192.168.0.0~192.168.255.255  
53. private static int[] IpCTypeRange;  
54.       
55. // A,B,C类地址的默认mask  
56. private static int DefaultIpAMask;  
57. private static int DefaultIpBMask;  
58. private static int DefaultIpCMask;  
59.       
60. // 初始化  
61. static  
62.      {  
63. new int[2];  
64. 0] = getIpV4Value("1.0.0.1");  
65. 1] = getIpV4Value("126.255.255.254");  
66.            
67. new int[2];  
68. 0] = getIpV4Value("128.0.0.1");  
69. 1] = getIpV4Value("191.255.255.254");  
70.            
71. new int[2];  
72. 0] = getIpV4Value("192.168.0.0");  
73. 1] = getIpV4Value("192.168.255.255");  
74.            
75. "255.0.0.0");  
76. "255.255.0.0");  
77. "255.255.255.0");  
78.      }  
79.       
80. /**
81.      * 默认255.255.255.0
82.      */  
83. public IpV4Util()  
84.      {  
85. "255.255.255.0");  
86.      }  
87.       
88. /**
89.      * @param mask 任意的如"255.255.254.0"等格式,如果格式不合法,抛出UnknownError异常错误
90.      */  
91. public IpV4Util(String masks)  
92.      {  
93.           mask = getIpV4Value(masks);  
94. if(mask == 0)  
95.           {  
96. throw new UnknownError();  
97.           }  
98.      }  
99.       
100. public int getMask()  
101.      {  
102. return mask;  
103.      }  
104.       
105. /**
106.      * 比较两个ip地址是否在同一个网段中,如果两个都是合法地址,两个都是非法地址时,可以正常比较;
107.      * 如果有其一不是合法地址则返回false;
108.      * 注意此处的ip地址指的是如“192.168.1.1”地址,并不包括mask
109.      * @return
110.      */  
111. public boolean checkSameSegment(String ip1,String ip2)  
112.      {  
113. return checkSameSegment(ip1,ip2,mask);  
114.      }  
115.       
116. /**
117.      * 比较两个ip地址是否在同一个网段中,如果两个都是合法地址,两个都是非法地址时,可以正常比较;
118.      * 如果有其一不是合法地址则返回false;
119.      * 注意此处的ip地址指的是如“192.168.1.1”地址
120.      * @return
121.      */  
122. public static boolean checkSameSegment(String ip1,String ip2, int mask)  
123.      {  
124. // 判断IPV4是否合法  
125. if(!ipV4Validate(ip1))  
126.           {  
127. return false;  
128.           }  
129. if(!ipV4Validate(ip2))  
130.           {  
131. return false;  
132.           }  
133. int ipValue1 = getIpV4Value(ip1);  
134. int ipValue2 = getIpV4Value(ip2);  
135. return (mask & ipValue1) == (mask & ipValue2);  
136.      }  
137.       
138. /**
139.      * 比较两个ip地址是否在同一个网段中,如果两个都是合法地址,两个都是非法地址时,可以正常比较;
140.      * 如果有其一不是合法地址则返回false;
141.      * 注意此处的ip地址指的是如“192.168.1.1”地址
142.      * @return
143.      */  
144. public static boolean checkSameSegmentByDefault(String ip1,String ip2)  
145.      {  
146. int mask = getDefaultMaskValue(ip1);     // 获取默认的Mask  
147. return checkSameSegment(ip1,ip2,mask);  
148.      }  
149.       
150. /**
151.      * 获取ip值与mask值与的结果
152.      * @param ipV4
153.      * @return  32bit值
154.      */  
155. public int getSegmentValue(String ipV4)  
156.      {  
157. int ipValue = getIpV4Value(ipV4);  
158. return (mask & ipValue);  
159.      }  
160.       
161. /**
162.      * 获取ip值与mask值与的结果
163.      * @param ipV4
164.      * @return  32bit值
165.      */  
166. public static int getSegmentValue(String ip, int mask)  
167.      {  
168. int ipValue = getIpV4Value(ip);  
169. return (mask & ipValue);  
170.      }  
171.       
172. /**
173.      * 判断ipV4或者mask地址是否合法,通过正则表达式方式进行判断
174.      * @param ipv4
175.      */  
176. public static boolean ipV4Validate(String ipv4)  
177.     {  
178. return ipv4Validate(ipv4,IPV4_REGEX);  
179.     }  
180.      
181. private static boolean ipv4Validate(String addr,String regex)  
182.     {  
183. if(addr == null)  
184.           {  
185. return false;  
186.          }  
187. else  
188.          {  
189. return Pattern.matches(regex, addr.trim());  
190.          }  
191.      }  
192.      
193. /**
194.      * 比较两个ip地址,如果两个都是合法地址,则1代表ip1大于ip2,-1代表ip1小于ip2,0代表相等;
195.      * 如果有其一不是合法地址,如ip2不是合法地址,则ip1大于ip2,返回1,反之返回-1;两个都是非法地址时,则返回0;
196.      * 注意此处的ip地址指的是如“192.168.1.1”地址,并不包括mask
197.      * @return
198.      */  
199. public static int compareIpV4s(String ip1,String ip2)  
200.      {  
201. int result = 0;  
202. int ipValue1 = getIpV4Value(ip1);     // 获取ip1的32bit值  
203. int ipValue2 = getIpV4Value(ip2); // 获取ip2的32bit值  
204. if(ipValue1 > ipValue2)  
205.           {  
206. 1;  
207.           }  
208. else if(ipValue1 <= ipValue2)  
209.           {  
210. 1;  
211.           }  
212. return result;  
213.      }  
214.       
215. /**
216.      * 检测ipV4 的类型,包括A类,B类,C类,其它(C,D和广播)类等
217.      * @param ipV4
218.      * @return     返回1代表A类,返回2代表B类,返回3代表C类;返回4代表D类
219.      */  
220. public static int checkIpV4Type(String ipV4)  
221.      {  
222. int inValue = getIpV4Value(ipV4);  
223. if(inValue >= IpCTypeRange[0] && inValue <= IpCTypeRange[1])  
224.           {  
225. return IP_C_TYPE;  
226.           }  
227. else if(inValue >= IpBTypeRange[0] && inValue <= IpBTypeRange[1])  
228.           {  
229. return IP_B_TYPE;  
230.           }  
231. else if(inValue >= IpATypeRange[0] && inValue <= IpATypeRange[1])  
232.           {  
233. return IP_A_TYPE;  
234.           }  
235. return IP_OTHER_TYPE;  
236.      }  
237.       
238. /**
239.      * 获取默认mask值,如果IpV4是A类地址,则返回{@linkplain #DefaultIpAMask},
240.      * 如果IpV4是B类地址,则返回{@linkplain #DefaultIpBMask},以此类推
241.      * @param anyIpV4 任何合法的IpV4
242.      * @return mask 32bit值
243.      */  
244. public static int getDefaultMaskValue(String anyIpV4)  
245.      {  
246. int checkIpType = checkIpV4Type(anyIpV4);  
247. int maskValue = 0;  
248. switch (checkIpType)  
249.           {  
250. case IP_C_TYPE:  
251.                     maskValue = DefaultIpCMask;  
252. break;  
253. case IP_B_TYPE:  
254.                     maskValue = DefaultIpBMask;  
255. break;  
256. case IP_A_TYPE:  
257.                     maskValue = DefaultIpAMask;  
258. break;  
259. default:  
260.                     maskValue = DefaultIpCMask;  
261.           }  
262. return maskValue;  
263.      }  
264.       
265. /**
266.      * 获取默认mask地址,A类地址对应255.0.0.0,B类地址对应255.255.0.0,
267.      * C类及其它对应255.255.255.0
268.      * @param anyIp
269.      * @return mask 字符串表示
270.      */  
271. public static String getDefaultMaskStr(String anyIp)  
272.      {  
273. return trans2IpStr(getDefaultMaskValue(anyIp));  
274.      }  
275.       
276. /**
277.      * 将ip 32bit值转换为如“192.168.0.1”等格式的字符串
278.      * @param ipValue 32bit值
279.      * @return
280.      */  
281. public static String trans2IpStr(int ipValue)  
282.      {  
283. // 保证每一位地址都是正整数  
284. return ((ipValue >> 24) & 0xff) + "." + ((ipValue >> 16) & 0xff) + "." + ((ipValue >> 8) & 0xff) + "." + (ipValue & 0xff);  
285.      }  
286.       
287. /**
288.      * 将ip byte数组值转换为如“192.168.0.1”等格式的字符串
289.      * @param ipBytes 32bit值
290.      * @return
291.      */  
292. public static String trans2IpV4Str(byte[] ipBytes)  
293.     {  
294. // 保证每一位地址都是正整数  
295. return (ipBytes[0] & 0xff) + "." + (ipBytes[1] & 0xff) + "." + (ipBytes[2] & 0xff) + "." + (ipBytes[3] & 0xff);  
296.     }  
297.   
298. public static int getIpV4Value(String ipOrMask)  
299.      {  
300. byte[] addr = getIpV4Bytes(ipOrMask);  
301. int address1  = addr[3] & 0xFF;  
302. 2] << 8) & 0xFF00);  
303. 1] << 16) & 0xFF0000);  
304. 0] << 24) & 0xFF000000);  
305. return address1;  
306.      }  
307.   
308. public static byte[] getIpV4Bytes(String ipOrMask)  
309.      {  
310. try  
311.           {  
312. "\\.");  
313. int length = addrs.length;  
314. byte[] addr = new byte[length];  
315. for (int index = 0; index < length; index++)  
316.                {  
317. byte) (Integer.parseInt(addrs[index]) & 0xff);  
318.                }  
319. return addr;  
320.           }  
321. catch (Exception e)  
322.           {  
323.           }  
324. return new byte[4];  
325.      }  
326. }  
 
  
应用



[java]  view plain copy



1. public static void main(String[] args) throws UnknownHostException  
2.     {  
3. // 判断ip两个地址的大小关系  
4. "10.8.9.116";  
5. "10.8.9.10";  
6. "ip1 大于 ip2? " + (compareIpV4s (ip1, ip2) > 0));  
7.   
8. "10.8.8.116";  
9. "10.10.9.10";  
10.             
11. "ip3 大于 ip4? " + (compareIpV4s (ip3, ip4) > 0));  
12.             
13. // 判断ip两个地址是否是同一个网段  
14. int mask1 = getIpV4Value( "255.255.255.0");  
15. int mask2 = getIpV4Value( "255.255.0.0");  
16.             
17. "ip1和ip2在同一个网段中? " + (checkSameSegment(ip1, ip2, mask1)));  
18.             
19. "ip3和ip4在同一个网段中 ?" + (checkSameSegment(ip3, ip4, mask2)));  
20.             
21. // 判断ip5是否在ip1和ip2范围中  
22. "10.8.8.8";  
23. // 假设ip1和ip2在同一个网段中,并且ip1为起始地址,ip2为结束地址,ip1<=1  
24. // 比较ip1与ip5是否在同一个网段中  
25. if(checkSameSegment(ip1, ip5, mask1))  
26.                 {  
27. // 判断ip5是否在ip1和ip2范围中  
28. if(((compareIpV4s(ip5, ip1)) >= 0) && (compareIpV4s(ip5, ip2) <= 0))  
29.                       {  
30. "ip5 在ip1-ip2范围内" );  
31.                       }  
32. else if ((compareIpV4s(ip5, ip1)) < 0)  
33.                       {  
34. "ip5 不在ip1-ip2范围内,因为ip5小于ip1" );  
35.                       }  
36. else  
37.                       {  
38. "ip5 不在ip1-ip2范围内,因为ip5大于ip2" );  
39.                       }  
40.                 }  
41. else  
42.                 {  
43. "ip5 不在ip1-ip2范围内,因为ip5不在ip1的网段中" );  
44.                 }  
45.     }