C#模拟post消息,实现登陆功能(包括CAS系统)
這方面的文章多得很,我這里把一些細節說一下。
1. 選用C#中的HttpWebRequest、HttpWebResponse和CookieContainer類。HttpWebRequest是用來提交web請求的,包括post和get;HttpWebResponse是用來接收服務器對本次請求的回復;CookieContainer是用來存放Cookie的集合,有些頁面只有登錄用戶才能查看。這個時候就需要保存Cookie,以便使登錄時建立的session保存下來這樣服務器就會認為我們一直是登錄狀態了。
2. 在瀏覽器中正常登錄一次,查看登錄時的post信息。我推薦使用FireFox瀏覽器+HttpFox插件。主要是查看post字符串和提交的URL。比如登錄上交葡萄(http://pt.sjtu.edu.cn/login.php),post的字符串為“username=test&password=123456”,對應的URL為“http://pt.sjtu.edu.cn/takelogin.php”。在HttpWebRequest中設置一些這些屬性即可實現登錄功能,關鍵的代碼如下:
string data = "username=test&password=123456";cookie = new CookieContainer();
byte[] byteArray = Encoding.UTF8.GetBytes(data);
request = (HttpWebRequest)HttpWebRequest.Create("http://pt.sjtu.edu.cn/takelogin.php");
request.CookieContainer = cookie;
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = byteArray.Length;
Stream stream = request.GetRequestStream();
stream.Write(byteArray, 0, byteArray.Length);
stream.Close();
response = (HttpWebResponse)request.GetResponse();
StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.UTF8);
string resPage = reader.ReadToEnd();
3. 如果服務器端設置了CAS服務器,登錄過程就會復雜一些。首先也是用HttpFox查看登錄過程,會發現當post用戶名+密碼后,會得到CAS服務器回送的一個轉移地址(臨時生成的URL)。訪問該URL,服務器回送一個JSESSIONID,作為本次會話的憑據,也是唯一的。將該JSESSIONID加入到CookieContainer中:
cookie.Add(new Uri("http://passport.xjtuns.cn"), new Cookie("JSESSIONID", jsessionid));
這時就已經登錄了,可以訪問登陸后才能訪問的頁面。
4. 最困難的情況,就是登陸頁面上面有圖片形式的驗證碼,我想到的解決方案有:人工參與、設置cookie和圖片識別。第一種方法,就是在試圖登錄時,將頁面的驗證碼圖片下載到本地,人眼識別后由程序繼續進行下面的工作。第二種方法,首先在瀏覽器中登錄一次,記錄下cookie中的信息(一般是c_expiresintv、c_secure_uid、 c_secure_pass、 c_secure_ssl、c_secure_login等信息,通過HttpFox都可以查看到),然后在程序中設置User-Agent和這些cookie數據,冒充瀏覽器。當然這個過程中,不要關閉瀏覽器。第三種方法比較困難,需要設計圖像處理和模式識別的算法,而且一旦一次提交錯誤,服務器會更新驗證碼圖片。
??? 如果驗證碼是純數字的,我的下一篇文章(http://blog.csdn.net/zheng_ai/archive/2010/08/15/5813693.aspx)或許能有所幫助。
轉載于:https://www.cnblogs.com/wangchunming/archive/2012/04/02/2430157.html
總結
以上是生活随笔為你收集整理的C#模拟post消息,实现登陆功能(包括CAS系统)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 实现选择排序算法
- 下一篇: 关于Ex010的改进