根據黃聰:C#模擬網站頁面POST數據提交表單(轉)
1 using System;
2 using System.Collections.Generic;
3 using System.IO;
4 using System.IO.Compression;
5 using System.Linq;
6 using System.Net;
7 using System.Text;
8 using System.Threading.Tasks;
9
10 namespace Client
11 {
12 public class POST_DATA
13 {
14 ///C#的提交表單方式主要有兩種WebClient與HttpWebRequest
15 ///
16
17 ///webClient
18 ///_url:提交數據網址
19 ///_data:提交數據
20 public static string WC_Post(string _url, string _data)
21 {
22 string postString = _data;//這里即為傳遞的參數,可以用工具抓包分析,也可以自己分析,主要是form里面每一個name都要加進來 "arg1=a&arg2=b"
23 byte[] postData = Encoding.UTF8.GetBytes(postString);//編碼,尤其是漢字,事先要看下抓取網頁的編碼方式
24 string url = _url;//地址
25 WebClient webClient = new WebClient();
26 webClient.Headers.Add("Content-Type", "application/x-www-form-urlencoded");//采取POST方式必須加的header,如果改為GET方式的話就去掉這句話即可
27 byte[] responseData = webClient.UploadData(url, "POST", postData);//得到返回字符流
28 string srcString = Encoding.UTF8.GetString(responseData);//解碼
29
30 return srcString;
31 }
32 ///
33
34 #region
35 // HttpWebRequest以及HttpWebResponse
36
37 //自認為與上次介紹的WebClient最大的不同之處在於HttpWebRequest更靈活,也更強大,比如,HttpWebRequest支持Cookie,而WebClient就不支持,因此,如果要登錄某個網站才能進行某些操作的時候,HttpWebResponse就派上用場了。
38
39 //補充:
40
41 //WebClient是可以操作Cookie的,因為 Cookie本質上就是個字符串,只要服務器返回的頭是“SetCooie:xxx”,所以,按照返回的格式做下處理(不能原樣返回,具體可以抓包分析下 格式),存起來,然后在HTTP請求頭上加上“Cookie:xxx”即可
42
43 //首先要提下Referer還有Cookie
44
45 //Referer:就是一般在瀏覽器中發送Http請求時帶的頭信息,被廣泛用來統計點擊信息,即從那個點擊而來,所以有些網站也會用這個性質來防盜鏈,很多時候如果什么圖片僅限內部交流之類的,就是用了這個原理。
46
47 //Cookie:某些網站為了辨別用戶身 份、進行session跟蹤而儲存在用戶本地終端上的數據(通常經過加密),通常大家登錄的時候就要用到它,登錄后,網站會儲存一個Cookie的東西在 本地計算機上,然后每次訪問網站時,便會把這個網站的Cookie也一並發送過去,服務器就憑借這個來確認你的身份。它是個重要信息,有些黑客也會通過盜 取Cookie的方式來侵入你的賬戶。
48 #endregion
49 public static string HWR_Post(string _url, string _referer, string _data)
50 {
51 HttpWebRequest request = (HttpWebRequest)WebRequest.Create(_url); //url:"POST請求的地址"
52 request.CookieContainer = new CookieContainer();
53 CookieContainer cookie = request.CookieContainer;//如果用不到Cookie,刪去即可
54 //以下是發送的http頭,隨便加,其中referer挺重要的,有些網站會根據這個來反盜鏈
55 request.Referer = _referer; //referer:http://localhost/index.php
56 request.Accept = "Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8";
57 request.Headers["Accept-Language"] = "zh-CN,zh;q=0.";
58 request.Headers["Accept-Charset"] = "GBK,utf-8;q=0.7,*;q=0.3";
59 request.UserAgent = "User-Agent:Mozilla/5.0 (Windows NT 5.1) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.202 Safari/535.1";
60 request.KeepAlive = true;
61 //上面的http頭看情況而定,但是下面倆必須加
62 request.ContentType = "application/x-www-form-urlencoded";
63 request.Method = "POST";
64
65 Encoding encoding = Encoding.UTF8;//根據網站的編碼自定義
66 byte[] postData = encoding.GetBytes(_data);//data即為發送的數據,格式還是和上次說的一樣
67 request.ContentLength = postData.Length;
68 Stream requestStream = request.GetRequestStream();
69 requestStream.Write(postData, 0, postData.Length);
70
71 HttpWebResponse response = (HttpWebResponse)request.GetResponse();
72 Stream responseStream = response.GetResponseStream();
73 //如果http頭中接受gzip的話,這里就要判斷是否為有壓縮,有的話,直接解壓縮即可
74 if (response.Headers["Content-Encoding"] != null && response.Headers["Content-Encoding"].ToLower().Contains("gzip"))
75 {
76 responseStream = new GZipStream(responseStream, CompressionMode.Decompress);
77 }
78
79 StreamReader streamReader = new StreamReader(responseStream, encoding);
80 string retString = streamReader.ReadToEnd();
81
82 streamReader.Close();
83 responseStream.Close();
84
85 return retString;
86 }
87 }
88 }