数据库ip存储的一点问题

PHP 林涛 2723℃ 0评论

最近在做屏蔽恶意点击,其中用到处理ip存储,由于考虑到ip量会很大,所以把ip保存成整形,使用INET_ATON和INET_NTOA。但是在之后查看结果的时候发现,127.255.255.255, 很多。经过研究发现问题是这样的:

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地址.
解决的办法:字段改为bigint类型。

如需转载请注明: 转载自26点的博客

本文链接地址: 数据库ip存储的一点问题

转载请注明:26点的博客 » 数据库ip存储的一点问题

喜欢 (1)
发表我的评论
取消评论

表情
(1)个小伙伴在吐槽
  1. 啊啊 😛
    匿名2018-03-25 17:30 回复