用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

PHP IP地址与整型互相转换详解

时间:2015-01-23  来源:西部数据  作者:西部数据

昨天要判断用户IP来源,然后再输入用户IP所在网段所在地址,我们第一条就需要把IP地址与整型互相转换功能实现,下面我来看看.

系统函数ip2long与long2ip

PHP中有内置函数ip2long可以将ip地址转换整型,代码如下:

$ip = '210.110.11.49';echo ip2long($ip);

输出:-764540111,输出的整型有负号是因为我们得到的结果是有符号整型,有符号整型最大值2147483647,要把结果转换为无符号型可以这么写 3530427185

使用long2ip把整型转换回ip地址,代码如下:

  1. $ip = '210.110.11.49'
  2. $ip_int = ip2long($ip); 
  3. echo $ip."<br />"
  4. echo $ip_int."<br />"
  5. echo long2ip($ip_int); 

输出:210.110.11.49,-764540111,210.110.11.49

从结果可以看到,ip与整型可以通过函数完成。

系统函数小bug:这中bug网上一搜都是,大意说的是ip某段加个前导0,先来看看这个bug实例,代码如下:

  1. $ip = '210.110.011.49'
  2. $ip_int = ip2long($ip); 
  3. echo $ip."<br />"
  4. echo $ip_int."<br />"
  5. echo long2ip($ip_int); 
  6. //输出: 
  7. //210.110.011.49 
  8. //-764540623 
  9. //210.110.9.49 

转换结果不匹配,我们试着在ip第一段数字前加前导0,再看看如下代码:

  1. $ip = '021.110.11.49'
  2. $ip_int = ip2long($ip); 
  3. echo $ip."<br />"
  4. echo $ip_int."<br />"
  5. echo long2ip($ip_int); 
  6. //输出: 
  7. //021.110.11.49 
  8. //292424497 
  9. //17.110.11.49 

转换结果都出错,以上例子都是因为加了前导0后导致转换结果出错,连带逆转结果与原转换ip不匹配.

转换原理,目前有两个算法:

第一、第一段乘以256的三次方,第二段乘以256的平方,第三段乘以256、最后总和,代码如下:

  1. $ip = '0210.110.11.49'
  2. function ipToInt($ip){ 
  3. $iparr = explode('.',$ip); 
  4. $num = 0; 
  5. for($i=0;$i<count($iparr);$i++){ 
  6. $num += intval($iparr[$i]) * pow(256,count($iparr)-($i+1)); 
  7. return $num
  8. echo $ip.'<br />'
  9. $ip_int = ipToInt($ip); 
  10. echo $ip_int.'<br />'
  11. echo long2ip($ip_int); 
  12. //输出: 
  13. //0210.110.11.49 
  14. //3530427185 
  15. //210.110.11.49 

第二、通过位运算符,代码如下:

  1. $ip = '0210.110.11.49'
  2. function ipToInt($ip){ 
  3. $iparr = explode('.',$ip); 
  4. return (intval($iparr[0]<<24))|(intval($iparr[1])<<16)|(intval($iparr[2])<<8)| (intval($iparr[3])); 
  5. echo $ip.'<br />'
  6. $ip_int = ipToInt($ip); 
  7. echo $ip_int.'<br />'
  8. echo long2ip($ip_int); 
  9. //输出: 
  10. //0210.110.11.49 
  11. //-764540111 
  12. //210.110.11.49 

检测IP是否合法

第一、自己遍历检测,代码如下:

  1. function check_ip($ip){ 
  2. $iparr = explode('.',$ip); 
  3. foreach($iparr as $v){ if($v>255) return false; } 
  4. return true; 
  5. echo '210.285.11.49,'
  6. var_dump(check_ip('210.285.11.49')); 
  7. echo '<br />'
  8. echo '210.205.11.49,'
  9. var_dump(check_ip('210.205.11.49')); 
  10. //输出: 
  11. //210.285.11.49,bool(false) 
  12. //210.205.11.49,bool(true) 

第二、使用ip2long返回,代码如下:

  1. function check_ip($ip){ 
  2. if(ip2long($ip)) return true; 
  3. return false; 
  4. echo '210.285.11.49,'
  5. var_dump(check_ip('210.285.11.49')); 
  6. echo '<br />'
  7. echo '210.205.11.49,'
  8. var_dump(check_ip('210.205.11.49')); 
  9. //输出: 
  10. //210.285.11.49,bool(false) 
  11. //210.205.11.49,bool(true)
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门