這篇文章主要介紹了關於PHP擷取用戶端真實IP地址的方法,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
php擷取用戶端IP地址有四種方法,這五種方法分別為REMOTE_ADDR、HTTP_CLIENT_IP、HTTP_X_FORWARDED_FOR、HTTP_VIA。
REMOTE_ADDR 是你的用戶端跟你的伺服器“握手”時候的IP。如果使用了“匿名代理”,REMOTE_ADDR將顯示Proxy 伺服器的IP。
HTTP_CLIENT_IP 是Proxy 伺服器發送的HTTP頭。如果是“超級匿名代理”,則返回none值。同樣,REMOTE_ADDR也會被替換為這個Proxy 伺服器的IP。
$_SERVER['REMOTE_ADDR']; //訪問端(有可能是使用者,有可能是代理的)IP
$_SERVER['HTTP_CLIENT_IP']; //代理端的(有可能存在,可偽造)
$_SERVER['HTTP_X_FORWARDED_FOR']; //使用者是在哪個IP使用的代理(有可能存在,也可以偽造)
三個值區別如下:
一、沒有使用Proxy 伺服器的情況:
REMOTE_ADDR = 您的 IP
HTTP_VIA = 沒數值或不顯示
HTTP_X_FORWARDED_FOR = 沒數值或不顯示
二、使用透明Proxy 伺服器的情況:Transparent Proxies
REMOTE_ADDR = 最後一個Proxy 伺服器 IP
HTTP_VIA = Proxy 伺服器 IP
HTTP_X_FORWARDED_FOR = 您的真實 IP ,經過多個Proxy 伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。
這類Proxy 伺服器還是將您的資訊轉寄給您的訪問對象,無法達到隱藏真實身份的目的。
三、使用普通匿名Proxy 伺服器的情況:Anonymous Proxies
REMOTE_ADDR = 最後一個Proxy 伺服器 IP
HTTP_VIA = Proxy 伺服器 IP
HTTP_X_FORWARDED_FOR = Proxy 伺服器 IP ,經過多個Proxy 伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。
隱藏了您的真實IP,但是向訪問對象透露了您是使用Proxy 伺服器訪問他們的。
四、使用欺騙性Proxy 伺服器的情況:Distorting Proxies
REMOTE_ADDR = Proxy 伺服器 IP
HTTP_VIA = Proxy 伺服器 IP
HTTP_X_FORWARDED_FOR = 隨機的 IP ,經過多個Proxy 伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。
告訴了訪問對象您使用了Proxy 伺服器,但編造了一個虛假的隨機IP代替您的真實IP欺騙它。
五、使用高匿名Proxy 伺服器的情況:High Anonymity Proxies (Elite proxies)
REMOTE_ADDR = Proxy 伺服器 IP
HTTP_VIA = 沒數值或不顯示
HTTP_X_FORWARDED_FOR = 沒數值或不顯示 ,經過多個Proxy 伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。
完全用Proxy 伺服器的資訊替代了您的所有資訊,就象您就是完全使用那台Proxy 伺服器直接存取對象。
六、擷取用戶端真實的IP地址執行個體:
function get_real_ip(){ $ip=FALSE; //用戶端IP 或 NONE if(!empty($_SERVER["HTTP_CLIENT_IP"])){ $ip = $_SERVER["HTTP_CLIENT_IP"]; } //多重Proxy 伺服器下的用戶端真實IP地址(可能偽造),如果沒有使用代理,此欄位為空白 if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) { $ips = explode (", ", $_SERVER['HTTP_X_FORWARDED_FOR']); if ($ip) { array_unshift($ips, $ip); $ip = FALSE; } for ($i = 0; $i < count($ips); $i++) { if (!eregi ("^(10│172.16│192.168).", $ips[$i])) { $ip = $ips[$i]; break; } } } //用戶端IP 或 (最後一個)Proxy 伺服器 IP return ($ip ? $ip : $_SERVER['REMOTE_ADDR']);}
以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!