2013-01-04 15:10:29  浏览:1508

ip mysql php

我个人觉得,ip地址保存到数据库中,112.98.105.155没有1885497755好,前者必须声明15位varchar,后者只需要声明11位的int类型,

所以比较喜欢用后者,

下面介绍php和mysql中,这两种类型的转换

php:首先通过代码获取到客户端ip,例如得到:112.98.105.155

然后通过函数sprintf ( "%u", ip2long ( $ip ) );得到int类型的ip: 1885497755

这里说明一下,为什么ip2long就已经转换了,还要用sprintf,因为仅仅用ip2long 有可能产生负数。

反之,则用long2ip($ip)得到112.98.105.155这种格式的ip


mysql中:

给出一个作为字符串的网络地址的点地址表示,返回一个代表该地址数值的整数。地址可以是4或8比特地址。

mysql> SELECT INET_ATON('112.98.105.155');

        -> 1885497755

产生的数字总是按照网络字节顺序。如上面的例子,数字按照 209×2563 + 207×2562 + 224×256 + 40 进行计算。

INET_ATON() 也能理解短格式 IP 地址:

mysql> SELECT INET_ATON('127.0.0.1'), INET_ATON('127.1');

        -> 2130706433, 2130706433

注释: 在存储由INET_ATON() 产生的值时,推荐你使用 INT UNSIGNED 列。假如你使用 (带符号) INT列, 则相应的第一个八位组大于127的IP 地址值会被截至  2147483647 (即, INET_ATON('127.255.255.255') 所返回的值)。请参见11.2节,“数值类型”

给定一个数字网络地址 (4 或 8 比特),返回作为字符串的该地址的电地址表示。

mysql> SELECT INET_NTOA(1885497755);

        -> '112.98.105.155'


返回首页