如何取得客戶端的真實IP? NOTIC: [8] Undefined variable: ip 這個錯怎麼改?

WBOY
發布: 2016-08-20 09:04:00
原創
1344 人瀏覽過

HTTP_CLIENT_IP
HTTP_X_FORWARD_IP
REMOTE_ADDR

依序探測? 還是有其他方法? 除了IP138?

下面的寫法,用最嚴格的文法來看,有哪裡不對,要怎麼改?

<code>    function Getip() {
        
        if (!empty($_SERVER["HTTP_CLIENT_IP"])) {
            $ip = $_SERVER["HTTP_CLIENT_IP"];
        }
        if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {//获取代理ip
            $ips = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
        }

        if ($ip) {
            $ips = array_unshift($ips, $ip);
        }
        $count = count($ips);
        for ($i = 0; $i < $count; $i++) {
            if (!preg_match("/^(10|172\.16|192\.168)\./i", $ips[$i])) {//排除局域网ip
                $ip = $ips[$i];
                break;
            }
        }
        $tip = $ip ? $ip : $_SERVER['REMOTE_ADDR'];
        if ($tip == "127.0.0.1") {//获得本地真实IP
            return $this -> get_onlineip();
        } else {
            return $tip;
        }

    }</code>
登入後複製
登入後複製

或用下面的函數?

<code>// 定义一个函数getIP() 
function getIP() 
{ 
global $ip; 

if (getenv("HTTP_CLIENT_IP")) 
$ip = getenv("HTTP_CLIENT_IP"); 
else if(getenv("HTTP_X_FORWARDED_FOR")) 
$ip = getenv("HTTP_X_FORWARDED_FOR"); 
else if(getenv("REMOTE_ADDR")) 
$ip = getenv("REMOTE_ADDR"); 
else 
$ip = "Unknow"; 

return $ip; 
} 

</code>
登入後複製
登入後複製

回覆內容:

HTTP_CLIENT_IP
HTTP_X_FORWARD_IP
REMOTE_ADDR

依序探測? 還是有其他方法? 除了IP138?

下面的寫法,用最嚴格的文法來看,有哪裡不對,要怎麼改?

<code>    function Getip() {
        
        if (!empty($_SERVER["HTTP_CLIENT_IP"])) {
            $ip = $_SERVER["HTTP_CLIENT_IP"];
        }
        if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {//获取代理ip
            $ips = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
        }

        if ($ip) {
            $ips = array_unshift($ips, $ip);
        }
        $count = count($ips);
        for ($i = 0; $i < $count; $i++) {
            if (!preg_match("/^(10|172\.16|192\.168)\./i", $ips[$i])) {//排除局域网ip
                $ip = $ips[$i];
                break;
            }
        }
        $tip = $ip ? $ip : $_SERVER['REMOTE_ADDR'];
        if ($tip == "127.0.0.1") {//获得本地真实IP
            return $this -> get_onlineip();
        } else {
            return $tip;
        }

    }</code>
登入後複製
登入後複製

或用下面的函數?

<code>// 定义一个函数getIP() 
function getIP() 
{ 
global $ip; 

if (getenv("HTTP_CLIENT_IP")) 
$ip = getenv("HTTP_CLIENT_IP"); 
else if(getenv("HTTP_X_FORWARDED_FOR")) 
$ip = getenv("HTTP_X_FORWARDED_FOR"); 
else if(getenv("REMOTE_ADDR")) 
$ip = getenv("REMOTE_ADDR"); 
else 
$ip = "Unknow"; 

return $ip; 
} 

</code>
登入後複製
登入後複製

目前來說這種方式是最保險的。
ip138只能拿到訪客的IP,如果是伺服器訪問,就是伺服器的IP

目前對這方面需求沒有過多研究,正常工作中是使用依序探測的方式取得。

其實普通用戶是不會刻意隱藏自己IP的. 也不會透過好幾層的代理去訪問你的服務. 所以依次判斷這三個其實就可以了. 對普通用戶而言, 這三個能拿到的IP的真實度也是蠻高的.

這個問題問的好,這個真不是個簡簡單單就能搞定的,客戶端ip有些是存在欺騙和代理的問題,所以在獲取的時候不是百分百的就能獲取到的。不過如其他網友所說一般用戶用代理什麼的還是很少的。相信自己用自己的方法就可以,或是參考其他第三方取得ip的類別庫也可以

相關標籤:
php
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板