首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否将IP存储为无符号整型?

是否将IP存储为无符号整型?
EN

Stack Overflow用户
提问于 2010-09-30 14:50:18
回答 5查看 5.4K关注 0票数 3

我读到在数据库中存储IP地址的最好方法是创建一个Unsigned Int(10)字段。如何使用PHP转换IP地址?我试过用

代码语言:javascript
复制
$this->ip = long2ip($_SERVER['REMOTE_ADDR']);

但这似乎行不通。我找到了将其转换回IP地址的方法

代码语言:javascript
复制
$this->ip = sprintf("%u", ip2long($result['ip']));

如何在开始时转换IP地址?我应该为此使用PHP吗?或者集成到MySQL查询中会更好?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-09-30 14:54:33

long2ip将整数转换为IP格式,而ip2long则相反。

因此,使用ip2long$_SERVER['REMOTE_ADDR']转换为整数以将其存储在数据库中,并在从数据库中读取整数后使用long2ip

代码语言:javascript
复制
$long = ip2long($_SERVER['REMOTE_ADDR']);
$ip   = long2ip($long);
票数 12
EN

Stack Overflow用户

发布于 2010-09-30 15:10:41

最好把这个逻辑放在你的SQL查询中:

代码语言:javascript
复制
INSERT INTO `table`
    (`ip`)
VALUES
    INET_ATON('192.168.0.1')

然后在选择数据时隐蔽地返回地址:

代码语言:javascript
复制
SELECT INET_NTOA(`ip`)
    FROM `table`
票数 12
EN

Stack Overflow用户

发布于 2010-09-30 14:55:11

我用了这个

代码语言:javascript
复制
function ip2int($ip) {
    $a = explode(".",$ip);
    return $a[0] * 256 * 256 * 256 + $a[1] * 256 * 256 + $a[2] * 256 + $a[3];
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3828409

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档