獲取客戶端真實ip

☆綠茶☆發表於2014-10-09

php中HTTP_X_FORWARDED_FOR 和 REMOTE_ADDR的使用 
1.REMOTE_ADDR:瀏覽當前頁面的使用者計算機的ip地址 
2.HTTP_X_FORWARDED_FOR: 瀏覽當前頁面的使用者計算機的閘道器 
3.HTTP_CLIENT_IP:客戶端的ip 

在PHP 中使用 $_SERVER["REMOTE_ADDR"] 來取得客戶端的 IP 地址,但如果客戶端是使用代理伺服器來訪問,那取到的就是代理伺服器的 IP 地址,而不是真正的客戶端 IP 地址。要想透過代理伺服器取得客戶端的真實 IP 地址,就要使用 $_SERVER["HTTP_X_FORWARDED_FOR"] 來讀取。 

不過要注意的事,並不是每個代理伺服器都能用 $_SERVER["HTTP_X_FORWARDED_FOR"] 來讀取客戶端的真實 IP,有些用此方法讀取到的仍然是代理伺服器的 IP。 

還有一點需要注意的是:如果客戶端沒有通過代理伺服器來訪問,那麼用$_SERVER["HTTP_X_FORWARDED_FOR"] 取到的值將是空的。 

if ($_SERVER['HTTP_X_FORWARDED_FOR'] && preg_match('/^([0-9]{1,3}\.){3}[0-9]{1,3}$/',$_SERVER['HTTP_X_FORWARDED_FOR'])) {  
      $onlineip = $_SERVER['HTTP_X_FORWARDED_FOR'];  
} elseif  ($_SERVER['HTTP_CLIENT_IP']  && preg_match('/^([0-9]{1,3}\.){3}[0-9]{1,3}$/',$_SERVER['HTTP_CLIENT_IP'])) {  
      $onlineip = $_SERVER['HTTP_CLIENT_IP']; 




獲取使用者IP地址的三個屬性的區別 (HTTP_X_FORWARDED_FOR,HTTP_VIA,REMOTE_ADDR) 
一、沒有使用代理服務 器的情況: 

REMOTE_ADDR = 您的 IP 
HTTP_VIA = 沒數值或不顯示 
HTTP_X_FORWARDED_FOR = 沒數值或不顯示 

二、使用透明代理伺服器的情 況:Transparent Proxies 

REMOTE_ADDR = 最後一個代理伺服器 IP 
HTTP_VIA = 代理伺服器 IP 
HTTP_X_FORWARDED_FOR = 您的真實 IP ,經過多個代理伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。 

這類代理伺服器還是將您的資訊轉發給您的訪問物件,無法達到隱藏真實身份的目的。 

三、使用普通匿名代理伺服器的情況:Anonymous Proxies 

REMOTE_ADDR = 最後一個代理伺服器 IP 
HTTP_VIA = 代理伺服器 IP 
HTTP_X_FORWARDED_FOR = 代理伺服器 IP ,經過多個代理伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。 

隱藏了您的真實IP,但是向訪問物件透露了您是使用代理伺服器訪問他們的。 

四、使用欺騙性代理伺服器的情況:Distorting Proxies 

REMOTE_ADDR = 代理伺服器 IP 
HTTP_VIA = 代理伺服器 IP 
HTTP_X_FORWARDED_FOR = 隨機的 IP ,經過多個代理伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。 

告訴了訪問物件您使用了代理伺服器,但編造了一個虛假的隨機IP代替您的真實IP欺騙它。 

五、使用高匿名代理伺服器的情況:High Anonymity Proxies (Elite proxies) 

REMOTE_ADDR = 代理伺服器 IP 
HTTP_VIA = 沒數值或不顯示 
HTTP_X_FORWARDED_FOR = 沒數值或不顯示 ,經過多個代理伺服器時,這個值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。 

完全用代理伺服器的資訊替代了您的所有資訊,就象您就是完全使用那臺代理伺服器直接訪問物件。 

 

http://qq398705749.iteye.com/blog/963818

相關文章