在使用Chrome和Firefox时,在Mysql中更新IP地址会产生不同的结果


Updating IP address in Mysql resulted different when using Chrome and Firefox

这个问题是指php mysql更新IP地址不能正常工作贴在这里希望得到一个答案。下面的代码更新数据库中的访问者IP地址。但是当使用Chrome进行测试时,结果是有线的。

输出为

字符串(119)"UPDATE ddns SET lasttip =1886947462, LastUpdate=now() WHERE ddns_name='kc001'

字符串(112)"select INET_NTOA(lasttip)作为IPADDR FROM ddns where ddns_name='kc001'112.120.136.134


但是当检查Mysql时,数据库中的lasttip实际上是2149463110。第二个查询也给我正确的IP地址。但在其他文件中查询时,得到的IP为128.30.52.70

使用Firefox或Safari时,数据库中的lasttip为1886947462,正确。

任何解释吗?

<?php
$dbh = mysql_connect("..mydatabase info..") or die("I cannot connect to the database");
mysql_select_db("glddns");
function getIP(){
    //Test if it is a shared client
    if (!empty($_SERVER['HTTP_CLIENT_IP'])){
        $ip_tmp=$_SERVER['HTTP_CLIENT_IP'];
    //Is it a proxy address
    }elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){
        $ip_tmp=$_SERVER['HTTP_X_FORWARDED_FOR'];
    }else{
        $ip_tmp=$_SERVER['REMOTE_ADDR'];
    }
    //The value of $ip at this point would look something like: "192.0.34.166"
    $ip = ip2long($ip_tmp);
    return $ip;
}
function getddns(){
        $var = explode(".",$_SERVER["SERVER_NAME"]);
        return $var[0];
}
$ipaddr = getIP();
$ddns = $_GET["ddns"];
$sql = sprintf("UPDATE ddns SET LastIP=%u, LastUpdate=now() WHERE ddns_name='%s'",$ipaddr,$ddns);
var_dump($sql);
$result = mysql_query($sql) or die("Query failed:".mysql_error());
if ($result && mysql_affected_rows()==1)
    echo "Update Done";
else
    echo "Update Failed";
$sql= sprintf("select INET_NTOA(LastIP) as IPADDR FROM ddns where ddns_name='%s'",$ddns);
echo "<br><br>";
var_dump($sql);
$result = mysql_query($sql) or die("Query failed:".mysql_error());
while($line = mysql_fetch_assoc($result)){
     echo "<br>". $line["IPADDR"];
}
mysql_free_result($result);
mysql_close($dbh);
?>

检查您的浏览器是否设置为使用(不同的)代理服务器

这是一件很奇怪的事情。以前在我的chrome上也发生过。现在问题不存在了。谢谢。