要判斷客戶端是否使用代理服務(wù)器,可以從客戶端所發(fā)送的環(huán)境變量信息來判斷。
具體來說,就是看http_via字段,如果這個字段設(shè)置了,說明客戶端使用了代理服務(wù)器。
匿名級別可以參考下表來判斷。
給出一個應(yīng)用例子,可以掛上代理試試效果: http://ip.mixsec.org/
一、沒有使用代理服務(wù)器的情況:
remote_addr = 您的 ip
http_via = 沒數(shù)值或不顯示
http_x_forwarded_for = 沒數(shù)值或不顯示
二、使用透明代理服務(wù)器的情況:transparent proxies
remote_addr = 代理服務(wù)器 ip
http_via = 代理服務(wù)器 ip (補充:這個字段由代理服務(wù)器填充,有時會填充網(wǎng)關(guān)信息等)
http_x_forwarded_for = 您的真實 ip
這類代理服務(wù)器還是將您的信息轉(zhuǎn)發(fā)給您的訪問對象,無法達到隱藏真實身份的目的。
三、使用普通匿名代理服務(wù)器的情況:anonymous proxies
remote_addr = 代理服務(wù)器 ip
http_via = 代理服務(wù)器 ip (補充:這個字段由代理服務(wù)器填充,有時會填充網(wǎng)關(guān)信息等)
http_x_forwarded_for = 代理服務(wù)器 ip
隱藏了您的真實ip,但是向訪問對象透露了您是使用代理服務(wù)器訪問他們的。
四、使用欺騙性代理服務(wù)器的情況:distorting proxies
remote_addr = 代理服務(wù)器 ip
http_via = 代理服務(wù)器 ip (補充:這個字段由代理服務(wù)器填充,有時會填充網(wǎng)關(guān)信息等)
http_x_forwarded_for = 隨機的 ip
告訴了訪問對象您使用了代理服務(wù)器,但編造了一個虛假的隨機ip代替您的真實ip欺騙它。
五、使用高匿名代理服務(wù)器的情況:high anonymity proxies
remote_addr = 代理服務(wù)器 ip
http_via = 沒數(shù)值或不顯示
http_x_forwarded_for = 沒數(shù)值或不顯示
完全用代理服務(wù)器的信息替代了您的所有信息,就象您就是完全使用那臺代理服務(wù)器直接訪問對象。
除此之外,可以通過proxy judges總 結(jié)其他一些可供參考的判定信息,一遍于在實踐中加以利用。
最后寫一個php例子,僅供大家參考:
代碼如下:
if(!empty($_server['http_via'])) //使用了代理
{
if(!isset($_server['http_x_forwarded_for']))
{
//anonymous proxies 普通匿名代理服務(wù)器
//代理ip地址為 $_server['remote_addr']
}
else
{
//transparent proxies 透明代理服務(wù)器
//代理ip地址為 $_server['remote_addr']
//真實ip地址為 $_server['http_x_forwarded_for']
}
}
else //沒有代理或者是高匿名代理
{
//真實ip地址為 $_server['remote_addr']
}
更多信息請查看IT技術(shù)專欄