如何判斷客戶端使用了代理服務(wù)器及其匿名級(jí)別 ?要判斷客戶端是否使用代理服務(wù)器,可以從客戶端所發(fā)送的環(huán)境變量信息來(lái)判斷,具體點(diǎn)就是看HTTP_VIA字段,如果這個(gè)字段設(shè)置了,說(shuō)明客戶端使用了代理服務(wù)器。
匿名級(jí)別可以參考下表來(lái)判斷。
給出一個(gè)應(yīng)用例子,可以掛上代理試試效果: http://ip.mixsec.org/
一、沒(méi)有使用代理服務(wù)器的情況:
REMOTE_ADDR = 您的 IP
HTTP_VIA = 沒(méi)數(shù)值或不顯示
HTTP_X_FORWARDED_FOR = 沒(méi)數(shù)值或不顯示
二、使用透明代理服務(wù)器的情況:Transparent Proxies
REMOTE_ADDR = 代理服務(wù)器 IP
HTTP_VIA = 代理服務(wù)器 IP (補(bǔ)充:這個(gè)字段由代理服務(wù)器填充,有時(shí)會(huì)填充網(wǎng)關(guān)信息等)
HTTP_X_FORWARDED_FOR = 您的真實(shí) IP
這類(lèi)代理服務(wù)器還是將您的信息轉(zhuǎn)發(fā)給您的訪問(wèn)對(duì)象,無(wú)法達(dá)到隱藏真實(shí)身份的目的。
三、使用普通匿名代理服務(wù)器的情況:Anonymous Proxies
REMOTE_ADDR = 代理服務(wù)器 IP
HTTP_VIA = 代理服務(wù)器 IP (補(bǔ)充:這個(gè)字段由代理服務(wù)器填充,有時(shí)會(huì)填充網(wǎng)關(guān)信息等)
HTTP_X_FORWARDED_FOR = 代理服務(wù)器 IP
隱藏了您的真實(shí)IP,但是向訪問(wèn)對(duì)象透露了您是使用代理服務(wù)器訪問(wèn)他們的。
四、使用欺騙性代理服務(wù)器的情況:Distorting Proxies
REMOTE_ADDR = 代理服務(wù)器 IP
HTTP_VIA = 代理服務(wù)器 IP (補(bǔ)充:這個(gè)字段由代理服務(wù)器填充,有時(shí)會(huì)填充網(wǎng)關(guān)信息等)
HTTP_X_FORWARDED_FOR = 隨機(jī)的 IP
告訴了訪問(wèn)對(duì)象您使用了代理服務(wù)器,但編造了一個(gè)虛假的隨機(jī)IP代替您的真實(shí)IP欺騙它。
五、使用高匿名代理服務(wù)器的情況:High Anonymity Proxies
REMOTE_ADDR = 代理服務(wù)器 IP
HTTP_VIA = 沒(méi)數(shù)值或不顯示
HTTP_X_FORWARDED_FOR = 沒(méi)數(shù)值或不顯示
完全用代理服務(wù)器的信息替代了您的所有信息,就象您就是完全使用那臺(tái)代理服務(wù)器直接訪問(wèn)對(duì)象。
除此之外,可以通過(guò)proxy judges總 結(jié)其他一些可供參考的判定信息,一遍于在實(shí)踐中加以利用。
最后寫(xiě)一個(gè)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']
//真實(shí)ip地址為 $_SERVER['HTTP_X_FORWARDED_FOR']
}
}
else //沒(méi)有代理或者是高匿名代理
{
//真實(shí)ip地址為 $_SERVER['REMOTE_ADDR']
}
posted on 2010-04-21 11:33
margin 閱讀(979)
評(píng)論(1) 編輯 收藏 引用 所屬分類(lèi):
Misc