PHP中的ip2long()是否等于MySQL中的INET_ATON()函数?

如果我们有一个IP地址如下:

127.0.0.1

这两个函数是否将ip地址转换为相同的数字,或者它们是否有所不同并且结果不同?
最佳答案
它们几乎完全一样. ip2long有时返回负值,因为PHP使用带符号的数字进行评估,而MySQL使用无符号.

两者都被评估为x *(2 ^ 24)y *(2 ^ 16)z *(2 ^ 8)w *(2 ^ 0),但在PHP中,由于长期签名,将显示某些负值IP地址.

For signed long,the range is 
(2^31) - 1 = 2,147,483,648 to +2,647

因此,转换为超过2,647的地址将回滚并给出负值.

ip2long("254.254.254.254"); // -16843010

这link详细描述了这一点.

dawei

【声明】:淮南站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。