<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>PHP中文网</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> </head> <body> <?php /* * 作者:XXXX */ //将IP转换为数字 function ipton($ip) { $ip_arr=explode('.',$ip);//分隔ip段 foreach ($ip_arr as $value) { $iphex=dechex($value);//将每段ip转换成16进制 if(strlen($iphex)<2)//255的16进制表示是ff,所以每段ip的16进制长度不会超过2 { $iphex='0'.$iphex;//如果转换后的16进制数长度小于2,在其前面加一个0 //没有长度为2,且第一位是0的16进制表示,这是为了在将数字转换成ip时,好处理 } $ipstr.=$iphex;//将四段IP的16进制数连接起来,得到一个16进制字符串,长度为8 } return hexdec($ipstr);//将16进制字符串转换成10进制,得到ip的数字表示 } //将数字转换为IP,进行上面函数的逆向过程 function ntoip($n) { $iphex=dechex($n);//将10进制数字转换成16进制 $len=strlen($iphex);//得到16进制字符串的长度 if(strlen($iphex)<8) { $iphex='0'.$iphex;//如果长度小于8,在最前面加0 $len=strlen($iphex); //重新得到16进制字符串的长度 } //这是因为ipton函数得到的16进制字符串,如果第一位为0,在转换成数字后,是不会显示的 //所以,如果长度小于8,肯定要把第一位的0加上去 //为什么一定是第一位的0呢,因为在ipton函数中,后面各段加的'0'都在中间,转换成数字后,不会消失 for($i=0,$j=0;$j<$len;$i=$i+1,$j=$j+2) {//循环截取16进制字符串,每次截取2个长度 $ippart=substr($iphex,$j,2);//得到每段IP所对应的16进制数 $fipart=substr($ippart,0,1);//截取16进制数的第一位 if($fipart=='0') {//如果第一位为0,说明原数只有1位 $ippart=substr($ippart,1,1);//将0截取掉 } $ip[]=hexdec($ippart);//将每段16进制数转换成对应的10进制数,即IP各段的值 } $ip = array_reverse($ip); return implode('.', $ip);//连接各段,返回原IP值 } echo ipton('119.255.31.226'); echo '<br>'; $num='379374783'; echo strlen($num).'<br/>'; echo ntoip($num).'<br/>'; echo 'trueipnum:'.ip2long('119.255.31.226').'<br/>'; echo 'trueip:'.long2ip('3793747831'); ?> </body> </html>
Mysql에는 IP 주소를 숫자로 변환하는 inet_aton 함수와 숫자를 IP로 변환하는 inet_ntoa 함수가 있습니다.
SELECT INET_ATON( '10.122.22.1' )
위 변환 함수는 웹마스터가 작성한 것인데 우연히 mysql 시스템 함수와 동일한 변환 효과를 얻습니다. 오랫동안 신났어요~ ~
PHP는 IP와 숫자의 변환을 실현하기 위해 ip2long과 long2ip라는 두 가지 기능을 제공하는 것으로 나타났습니다. 웹마스터가 쓸데없는 작업을 수행했지만 논리적으로 연습해야 합니다. 생각~~
두 가지 구현 방법이 있는데, 하나는 프로그래밍 방식으로 구현하는 것이고, 하나는 SQL 문으로 직접 구현하는 것입니다. 매우 편리하고 좋습니다. 블로그에 저장해서 잊어버리지 않도록 하세요. 미래.
IP 데이터를 데이터베이스(MySQL)에 저장할 때 ip2long 함수를 사용하여 정수를 생성한 후 int(11) 유형 필드에 저장하는 데 익숙합니다. 그러나 다른 시스템에서는 다릅니다. 플랫폼 위에서는 ip2long 함수로 얻은 값이 다르기 때문에 데이터베이스에서 데이터를 읽고 long2ip를 사용하여 IP를 얻을 때 오류가 발생할 수 있습니다.
int를 사용합니다. (11) ip2long을 사용하여 IP 주소를 처리한 결과를 저장하려면 (범위 -2147483648 - 2147483647)을 입력합니다. 예를 들어, ip가 '202.105.77.179'인 경우 32비트 시스템에서 얻은 결과는 -899068493입니다. , 그러나 64비트 시스템에서는 3395898803을 얻습니다. 그런 다음 데이터베이스에 기록합니다. int(11)의 범위를 초과하므로 64비트 시스템의 결과는 int(11)의 최대값: 2147483647로 저장됩니다. 따라서 데이터베이스에서 가져오면 잘못된 결과가 나오면 IP 주소가 "127.255.255.255"가 됩니다.
예를 들어 INET_ATON과 같은 많은 솔루션을 사용할 수 있습니다. 및 INET_NTOA를 사용하여 IP 주소를 처리하거나 IP 주소를 저장하는 필드를 bigint 유형으로 변경하여 64비트 시스템에 저장되더라도 long2ip 함수를 사용하여 올바른 결과를 얻을 수 있습니다. 🎜>