在mysql数据库中保存IP地址

时间:2014-10-27 09:48:07

标签: php mysql

我将IP地址保存到DataBase

时遇到问题

这就是我获取ip的方式:

function getUserIP()
{
    $client  = @$_SERVER['HTTP_CLIENT_IP'];
    $forward = @$_SERVER['HTTP_X_FORWARDED_FOR'];
    $remote  = $_SERVER['REMOTE_ADDR'];

    if(filter_var($client, FILTER_VALIDATE_IP))
    {
        $ip = $client;
    }
    elseif(filter_var($forward, FILTER_VALIDATE_IP))
    {
        $ip = $forward;
    }
    else
    {
        $ip = $remote;
    }

    return $ip;
}


$user_ip = getUserIP();

这是我的数据库表创建php文件

$sql =  "CREATE TABLE users (".
            "ID         INT     NOT NULL    AUTO_INCREMENT,".
            "Guest          VARCHAR(60)     COLLATE utf16_general_ci,".
                        "IPAdd          INT UNSIGNED    NULL            DEFAULT NULL,".
            "PRIMARY KEY(ID));";

    $retval = mysql_query( $sql, $conn );

结束这是我保存用户IP的方式

require("DBConnection.php");
require("getIP.php");

echo $user_ip."<br>";
if ($user_ip === '::1'){
    $user_ip = '127.0.0.1';
}
$user_ip = ip2long ($user_ip);
echo $user_ip."<br>";
//Проверява ме за вече съществъващ гост
$selectData  = mysql_query("SELECT * FROM users"); 
if (!$selectData ) 
{
        die('Could not get data: ' . mysql_error());
}
else {
    $i = 1; // index za poreden nomer na potrebitelq.
    $guest = 'Guest'.$i;
    while ($row = mysql_fetch_array($selectData) )
    {
        if($row[1] == $guest && $row[2] != $user_ip )
        {
            $i++;
            $guest = 'Guest'.$i;
        }     
    }
    $sql = "INSERT INTO `cssgendb`.`users` (`ID`, `Guest`, 'IPAdd') 
            VALUES ('0', '$guest', '$user_ip');";
    $_SESSION['is_logged'] = true;
    $_SESSION['Name'] = $guest;
}
$retval = mysql_query( $sql, $conn );
if(! $retval )
    {
      die('Could not enter data: ' . mysql_error());
    }
    echo "Session Start successfully\n";    
mysql_close($conn);

我的想法是让用户获得IP并保存。如果用户IP不存在于DataBase中,则帐户将被创建为“Guest1”... IPAdd“127.0.0.1”;

3 个答案:

答案 0 :(得分:1)

您有两个选择:

  1. 将IPAdd列的数据类型从Unsigned Int更改为Varchar,以字符串格式保存ip
  2. 在通过调用ip2long
  3. 进行保存之前将IP转换为长格式

    如前所述,您应该考虑从mysql *切换到mysqli或PDO_MySQL,因为不推荐使用mysql *函数。

答案 1 :(得分:0)

您需要更改IPAdd的数据类型,您无法在整数字段中保存127.0.0.1之类的数据或任何IP地址。您只能在此字段

中保存没有.的正整数或负整数值

将您的数据类型更改为varchar,就像这样

ALTER TABLE `users` CHANGE `IPAdd` `IPAdd` VARCHAR( 20 ) NULL

答案 2 :(得分:0)

将ipadd字段更改为(int)和 使用$_SERVER['SERVER_ADDR']获取用户系统IP地址..