后端开发|php教程
PHP
后端开发-php教程
斗音视频解析源码,ubuntu 多串口终端,快手爬虫连麦,php 整数取反,谷歌 seo教程lzw
;$num=379374783;echo strlen($num).
;echo ntoip($num).
; echo rueipnum:.ip2long(119.255.31.226).
;echo rueip:.long2ip(3793747831);?>
mysql自带了inet_aton函数来实现将ip地址转换为数字,inet_ntoa函数将数字转换为ip。
08影院源码3.2,vscode删除线是什么,ubuntu加ppa,外网访问tomcat问题,js 爬虫 ajax,php 继承接口,金华seo外包公司费用,文章资讯图文网站源码,会员中心dedecms模板lzw
SELECT INET_ATON( ‘10.122.22.1’ )
ios webapp 源码下载,ubuntu硬件加速,检测tomcat环境变量,python爬虫天眼,php程序编写,魏县来商机seo关键词优化流程lzw
上面的转换函数为站长原创,碰巧实现了跟mysql系统函数相同的转换效果,呵呵,兴奋好久~~
原来PHP提供了ip2long和long2ip2个函数来实现IP与数字的转换,站长做了无用功了,不过权当锻炼逻辑思维吧~~
这是两种实现方法,一种是在程序上实现;一种是直接在sql语句中实现,很方便,不错,保存下来了,发到自己的博客,以后就不会忘记了。
把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函数仍能得到正确的结果.