php - 使用准备好的语句保存远程 IP

标签 php mysql

我正在尝试将远程用户 IP 保存在数据库中。为此,我将列创建为 int(10) UNSIGNED

当我这样尝试时,一切正常,但 IP 保存为 127.0.0.1

$ipaddr = $_SERVER['REMOTE_ADDR'];
$stmt = $pdo->prepare('INSERT INTO comment (body, author, email, date, url, ip) VALUES (:body, :author, :email, NOW(), :url, :ipaddr)');

$stmt->execute(array(
    ':body' => $_POST['k3jZGEeX1k1oo'],
    ':author' => $_POST['k3k0xKicU0eHQ'],
    ':email' => $email,
    'url' => $url,
    'ip' => $ipaddr
));

当我尝试使用 INET_ATON 时,数据库中没有任何内容。

$ipaddr = $_SERVER['REMOTE_ADDR'];
$stmt = $pdo->prepare('INSERT INTO comment (body, author, email, date, url, ip) VALUES (:body, :author, :email, NOW(), :url, :INET_ATON(ipaddr))');

$stmt->execute(array(
        ':body' => $_POST['k3jZGEeX1k1oo'],
        ':author' => $_POST['k3k0xKicU0eHQ'],
        ':email' => $email,
        'url' => $url,
        'ip' => $ipaddr
));

注意 :INET_ATON(ipaddr)。我如何使用准备好的语句来做到这一点?

最佳答案

如@Fred-ii- 所述,您应该检查错误。我也可以推荐this solution并内置 php 函数 ip2long .在你的情况下将是

$ipaddr = $_SERVER['REMOTE_ADDR'];
$ip = sprintf("%u", ip2long($ipaddr));

$stmt = $pdo->prepare('INSERT INTO comment (body, author, email, date, url, ip) VALUES (:body, :author, :email, NOW(), :url, :ip)');

$stmt->execute(array(
    ':body' => $_POST['k3jZGEeX1k1oo'],
    ':author' => $_POST['k3k0xKicU0eHQ'],
    ':email' => $email,
    ':url' => $url,
    ':ip' => $ip
));

要选择并查看实际 IP,您可以在查询中使用 INET_NTOA(再次来自 @Fred-ii- 评论)。

关于php - 使用准备好的语句保存远程 IP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44208332/

相关文章:

php - Google Translate 翻译内联 Javascript 代码

php - 对象错误: function query on a non-object

mysql - 使用where条件显示表

mysql - 我可以在 MySQL 查询中使用 preg_replace 或 regex 吗?

mysql - 如何处理 REST API 端点上的结果过滤?

javascript - 提交表单而不刷新页面 ajax,php,javascript?

PHP 错误 T_object_operator

javascript - $this 在 AJAX 请求后失去焦点

php - 白屏数据库插件 Codeigniter

mysql - 如何将变量从r程序传递到mysql函数