php中ip转int 并存储在mysql数据库

遇到一个问题,因而百度一下。 获得最佳答案 http://blog.163.com/metlive@126/blog/static/1026327120104232330131/php

 

 

如何将四个字段以点分开的IP网络址协议地址转换成整数呢?PHP里有这么一个函数ip2long.好比
<?php
echo ip2long("10.2.1.3");
?>
咱们将获得
167903491
这是如何计算的,目前我知道有两个算法。其一
<?php
function ip2int($ip){
    //咱们先把ip分为四段,$ip1,$ip2,$ip3,$ip4
    list($ip1,$ip2,$ip3,$ip4)=explode(".",$ip);
    //而后第一段乘以256的三次方,第二段乘以256的平方,第三段乘以256
    //这便是咱们获得的值
    return $ip1*pow(256,3)+$ip2*pow(256,2)+$ip3*256+$ip4;
}
?>
其二,用位运算
<?php
function ip2int($ip){
    list($ip1,$ip2,$ip3,$ip4)=explode(".",$ip);
    return ($ip1<<24)|($ip2<<16)|($ip3<<8)|($ip4);
}
?>
咱们会发现,有些ip转化成整数后,是负的,这是由于获得的结果是有符号整型,最大值是2147483647.要把它转化为无符号的,能够用
sprintf("%u",ip2long($ip);
就能转换为正整数。并且获得的结果用long2ip也能够正常转换回原来的ip地址。也能够用ip2long来验证一个ip是不是有效的,如
<?php
function chk_ip($ip){
    if(ip2long($ip)=="-1") {
       return false;
    }
    return true;
}
//应用
var_export(chk_ip("10.111.149.42"));
var_export(chk_ip("10.111.256.42"));
?>
将输出true和falsemysql

把ip数据保存在数据库(MySQL)中时候,咱们习惯用ip2long函数生成整型,而后存放在一个int(11)类型的字段中,可是,在不一样的系统平台上,ip2long函数获得的值是不一样的,所以可能形成在从数据库中读出数据,用long2ip获得ip的时候产生错误,说一下咱们碰到的状况:
咱们用一个int(11)类型(范围-2147483648 - 2147483647)来保存把一个ip地址用ip2long处理获得的结果,例如ip是’202.105.77.179′,那么在32位机器上获得的结果是:-899068493,而在64位机器上却获得3395898803.而后把它写入数据库,因为超过int(11)的范围,所以64位机器上的结果被保存为int(11)的最大值:2147483647.因而在从数据库中取出的时候,便获得了错误的结果,会获得”127.255.255.255″这个ip地址.
解决的办法不少,好比能够用mysql的函数:INET_ATON和INET_NTOA来处理ip地址;或者把保存ip地址的字段改成bigint类型,这样在64位机器上虽然保存的是3395898803,使用long2ip函数仍能获得正确的结果.算法

相关文章
相关标签/搜索