国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

asp.net 獲取IP的相關(guān)資料

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:43:51
文檔

asp.net 獲取IP的相關(guān)資料

asp.net 獲取IP的相關(guān)資料:ASP.net 獲得客戶端的IP,最常見的是使用下述代碼: 代碼如下:string user_IP = System.Web.HttpContext.Current.Request.ServerVariables[REMOTE_ADDR]; 對于了解代理服務(wù)器情況的人,我們會(huì)知道,如果用戶使用了代理服務(wù)器,上述代碼獲得的是代理
推薦度:
導(dǎo)讀asp.net 獲取IP的相關(guān)資料:ASP.net 獲得客戶端的IP,最常見的是使用下述代碼: 代碼如下:string user_IP = System.Web.HttpContext.Current.Request.ServerVariables[REMOTE_ADDR]; 對于了解代理服務(wù)器情況的人,我們會(huì)知道,如果用戶使用了代理服務(wù)器,上述代碼獲得的是代理

ASP.net 獲得客戶端的IP,最常見的是使用下述代碼:
代碼如下:

string user_IP = System.Web.HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"];

對于了解代理服務(wù)器情況的人,我們會(huì)知道,如果用戶使用了代理服務(wù)器,上述代碼獲得的是代理服務(wù)器的IP地址;如果用戶使用了多個(gè)代理服務(wù)器,則是到達(dá)服務(wù)器的最后一個(gè)代理服務(wù)器的IP地址。

REMOTE_ADDR 說明:

訪問客戶端的 IP 地址。
此項(xiàng)信息用戶不可以修改。
如果真的給改了的話,你也和服務(wù)器連接不了了,服務(wù)器就是按照這個(gè)來與客戶端建立連接并進(jìn)行通訊的。實(shí)際我測試修改這個(gè) ServerVariables , 一點(diǎn)效果都沒有。仍然獲得是實(shí)際的值。
另: Request.UserHostAddress 和 Request.ServerVariables["REMOTE_ADDR"] 實(shí)際是同一個(gè)值。

如何繞過代理服務(wù)器獲得用戶真實(shí)的IP地址呢? 這時(shí)候我們一般是類似如下的代碼(這里我簡單起見,沒有作一些邊界判斷)

private static string getIp(){
if (System.Web.HttpContext.Current.Request.ServerVariables["HTTP_VIA"] != null)
return System.Web.HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"].Split(new char[]{','})[0];
else
return System.Web.HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"];
}
這樣就足夠了么? 這樣是有問題的,HTTP_X_FORWARDED_FOR 、HTTP_VIA 是可以被冒名的。如果正好這里有SQL注入問題的話,那可非常嚴(yán)重了。

下面我們就來具體看HTTP_VIA 和HTTP_X_FORWARDED_FOR 這兩個(gè) ServerVariables。

HTTP_VIA

如果有該條信息, 就證明您使用了代理服務(wù)器,代理服務(wù)器的地址就是后面的數(shù)值。

HTTP_X_FORWARDED_FOR

如果有該條信息, 也證明了您使用了代理服務(wù)器代理服務(wù)器的地址就是后面的數(shù)值。

需要注意的,HTTP_X_FORWARDED_FOR 的值,并不一定是只有一個(gè)IP地址,下面的信息也是可能的,每行一條記錄。下面數(shù)據(jù)取材于CSDN 實(shí)際的數(shù)據(jù)。
10.194.73.11
unknown, unknown, 211.100.22.30
203.98.182.163, 203.98.182.163, 203.129.72.215
172.16.20.110, 202.116.64.196, 203.81.21.61
10.194.75.83, 10.194.73.11, 10.194.73.11, unknown
192.168.120.57, unknown, unknown, 211.10.10.195
10.2.4.211, 219.141.250.3
3.242.165.168, 218.108.22.164
unknown, 211.100.22.30
192.168.83.56, 210.21.224.233
218.94.136.176, 203.81.21.61
unknown, 210.75.1.181
10.161.196.218, 202.104.134.23
222.216.6.148, 222.216.6.146
155.161.59.47, unknown


需要注意的是這兩個(gè)值都是可以被改掉的。

對于這三個(gè)值:REMOTE_ADDR、HTTP_VIA、HTTP_X_FORWARDED_FOR 來說,可以分以下五種情況:

一、沒有使用代理服務(wù)器的情況:

REMOTE_ADDR = 您的 IP
HTTP_VIA = 沒數(shù)值或不顯示
HTTP_X_FORWARDED_FOR = 沒數(shù)值或不顯示

二、使用透明代理服務(wù)器的情況:Transparent Proxies

REMOTE_ADDR = 最后一個(gè)代理服務(wù)器 IP
HTTP_VIA = 代理服務(wù)器 IP
HTTP_X_FORWARDED_FOR = 您的真實(shí) IP ,經(jīng)過多個(gè)代理服務(wù)器時(shí),這個(gè)值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。

這類代理服務(wù)器還是將您的信息轉(zhuǎn)發(fā)給您的訪問對象,無法達(dá)到隱藏真實(shí)身份的目的。

三、使用普通匿名代理服務(wù)器的情況:Anonymous Proxies

REMOTE_ADDR = 最后一個(gè)代理服務(wù)器 IP
HTTP_VIA = 代理服務(wù)器 IP
HTTP_X_FORWARDED_FOR = 代理服務(wù)器 IP ,經(jīng)過多個(gè)代理服務(wù)器時(shí),這個(gè)值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。

隱藏了您的真實(shí)IP,但是向訪問對象透露了您是使用代理服務(wù)器訪問他們的。

四、使用欺騙性代理服務(wù)器的情況:Distorting Proxies

REMOTE_ADDR = 代理服務(wù)器 IP
HTTP_VIA = 代理服務(wù)器 IP
HTTP_X_FORWARDED_FOR = 隨機(jī)的 IP ,經(jīng)過多個(gè)代理服務(wù)器時(shí),這個(gè)值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。

告訴了訪問對象您使用了代理服務(wù)器,但編造了一個(gè)虛假的隨機(jī)IP代替您的真實(shí)IP欺騙它。

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

REMOTE_ADDR = 代理服務(wù)器 IP
HTTP_VIA = 沒數(shù)值或不顯示
HTTP_X_FORWARDED_FOR = 沒數(shù)值或不顯示 ,經(jīng)過多個(gè)代理服務(wù)器時(shí),這個(gè)值類似如下:203.98.182.163, 203.98.182.163, 203.129.72.215。

完全用代理服務(wù)器的信息替代了您的所有信息,就象您就是完全使用那臺(tái)代理服務(wù)器直接訪問對象。

服務(wù)器端的 UserIP.ASPX 頁面的代碼:
代碼如下:


protected void Page_Load(object sender, EventArgs e){
StringBuilder info = new StringBuilder(); // 我們關(guān)注的三個(gè) ServerVariables
info.AppendFormat("HTTP_VIA = {0} <br />\r\n",
Request.ServerVariables["HTTP_VIA"]);
info.AppendFormat("HTTP_X_FORWARDED_FOR = {0} <br />\r\n",
Request.ServerVariables["HTTP_X_FORWARDED_FOR"]);
info.AppendFormat("REMOTE_ADDR = {0} <br />\r\n",
Request.ServerVariables["REMOTE_ADDR"]);
info.AppendLine("*********** \r\n<br />");
// 其他有參考價(jià)值的 ServerVariables
foreach (string key in Request.ServerVariables.AllKeys){
info.AppendFormat("{0} = {1} <br />\r\n", key, Request.ServerVariables[key]);
}
Response.Clear();
Response.Write(info.ToString());
Response.End();
}
客戶端發(fā)送請求的代碼:
[code]
static void Main(string[] args){
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create("http://localhost:7867/MyTestWebSite/UserIP.aspx");
request.Headers.Add("REMOTE_ADDR", "192.168.5.88");
request.Headers.Add("VIA", "ghj1976");
request.Headers.Add("X_FORWARDED_FOR", "0.0.0.0");
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
StreamReader stream = new StreamReader(response.GetResponseStream());
string info = stream.ReadToEnd();
stream.Close();
response.Close();
request = null;
Console.Write(info);
Console.ReadLine();
}

測試的結(jié)果中的重要信息:測試的結(jié)果數(shù)據(jù)比較多,我這里只羅列了幾個(gè)重要的。

HTTP_VIA = ghj1976 <br />
HTTP_X_FORWARDED_FOR = 0.0.0.0 <br />
REMOTE_ADDR = 127.0.0.1 <br />
***********
REMOTE_ADDR = 127.0.0.1 <br />
HTTP_VIA = ghj1976 <br />
HTTP_REMOTE_ADDR = 192.168.5.88 <br />
HTTP_X_FORWARDED_FOR = 0.0.0.0 <br />

上面測試代碼需要注意的是:

我們在客戶端代碼中設(shè)置了三個(gè)HTTP頭信息,分別是:

REMOTE_ADDR、VIA、X_FORWARDED_FOR
實(shí)際在服務(wù)器段,這三個(gè)值應(yīng)該通過下面三個(gè)屬性來讀取

HTTP_REMOTE_ADDR、HTTP_VIA 、HTTP_X_FORWARDED_FOR 注意他們的區(qū)別!!

REMOTE_ADDR 屬性是無法設(shè)置的。或者說,設(shè)置的不是我們所希望的。

小結(jié):

1、REMOTE_ADDR 不可被修改,但是可能會(huì)獲得代理服務(wù)器的IP,而不是實(shí)際客戶端的IP。
2、通過 HTTP_VIA、HTTP_X_FORWARDED_FOR 我們可以獲得代理服務(wù)器所代理的信息,但是這依靠代理服務(wù)器的支持。另外,這兩個(gè)值可以被修改。我們通過它獲得的信息可能是不真實(shí)的。另,HTTP_X_FORWARDED_FOR 的信息可能是一個(gè)集合,不含 REMOTE_ADDR 中的代理服務(wù)器IP。
沒有一個(gè)完美的解決獲得客戶端IP地址的方法,我們只能在上面2個(gè)信息中取舍。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

asp.net 獲取IP的相關(guān)資料

asp.net 獲取IP的相關(guān)資料:ASP.net 獲得客戶端的IP,最常見的是使用下述代碼: 代碼如下:string user_IP = System.Web.HttpContext.Current.Request.ServerVariables[REMOTE_ADDR]; 對于了解代理服務(wù)器情況的人,我們會(huì)知道,如果用戶使用了代理服務(wù)器,上述代碼獲得的是代理
推薦度:
標(biāo)簽: IP地址 ip 取得
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美激情首页 | 亚洲欧美日韩高清中文在线 | 国产精品不卡 | 欧美日韩精品免费一区二区三区 | 欧美爱爱图 | 亚洲国产日韩在线精品频道 | 欧美日韩精品免费一区二区三区 | 日韩在线电影 | 国产a级一级久久毛片 | er久99久热只有精品国产 | 国产一在线精品一区在线观看 | 在线亚洲欧美日韩 | 欧美日韩一二 | 精品国产一区二区三区在线 | 亚洲欧美字幕 | 国产欧美综合一区二区 | 亚洲男同网站 | 欧美激情影音先锋 | 在线日韩欧美 | 国产亚洲欧美在线人成aaaa | 日韩亚洲国产综合久久久 | 欧美在线 | 亚洲 | 99国产精品 | 亚洲欧美视频一区 | 另类一区| 亚洲精品国产自在久久出水 | 久久精品成人国产午夜 | 久久久久久国产精品视频 | 亚洲欧美日韩专区 | 国产中文字幕视频 | 香蕉乱码成人久久天堂爱免费 | 台湾一级毛片永久免费 | 久久伊人精品一区二区三区 | 欧美天天搞| 91精品一区二区三区在线播放 | 日韩国产欧美视频 | 一区二区三区四区视频 | 美女视频黄a视频全免费应用 | 午夜精品久久久久久毛片 | 亚洲综合日韩在线亚洲欧美专区 | 久久久亚洲欧美综合 |