java模擬Cookies登陸


在使用java訪問URL時,如果該URL需要身份驗證,那么就不能夠直接訪問,因為沒有登陸。那么,如何解決這個問題呢?

      方法是使用java模擬登陸,登陸后記錄下cookie信息,在下次發起請求時時將cookie發送過去用以表明身份,這樣就能夠訪問帶有權限的URL了。

      下面首先介紹使用java模擬登陸。

[java] view plain copy
  1.               // 連接地址(通過閱讀html源代碼獲得,即為登陸表單提交的URL)  
  2. String surl = "http://login.goodjobs.cn/index.php/action/UserLogin";  
  3.   
  4. /** 
  5.  * 首先要和URL下的URLConnection對話。 URLConnection可以很容易的從URL得到。比如: // Using 
  6.  * java.net.URL and //java.net.URLConnection 
  7.  */  
  8. URL url = new URL(surl);  
  9. HttpURLConnection connection = (HttpURLConnection) url.openConnection();  
  10.   
  11. /** 
  12.  * 然后把連接設為輸出模式。URLConnection通常作為輸入來使用,比如下載一個Web頁。 
  13.  * 通過把URLConnection設為輸出,你可以把數據向你個Web頁傳送。下面是如何做: 
  14.  */  
  15. connection.setDoOutput(true);  
  16. /** 
  17.  * 最后,為了得到OutputStream,簡單起見,把它約束在Writer並且放入POST信息中,例如: ... 
  18.  */  
  19. OutputStreamWriter out = new OutputStreamWriter(connection  
  20.         .getOutputStream(), "GBK");  
  21.               //其中的memberName和password也是閱讀html代碼得知的,即為表單中對應的參數名稱  
  22. out.write("memberName=myMemberName&password=myPassword"); // post的關鍵所在!  
  23. // remember to clean up  
  24. out.flush();  
  25. out.close();  
  26.   
  27. // 取得cookie,相當於記錄了身份,供下次訪問時使用  
  28. String cookieVal = connection.getHeaderField("Set-Cookie");  

      登陸成功后,即可訪問其他URL了。

[java] view plain copy
  1.               String s = "http://user.goodjobs.cn/dispatcher.php/module/Resume/action/Preview";  
  2. //重新打開一個連接  
  3.               url = new URL(s);  
  4. HttpURLConnection resumeConnection = (HttpURLConnection) url  
  5.         .openConnection();  
  6. if (cookieVal != null) {  
  7.                       //發送cookie信息上去,以表明自己的身份,否則會被認為沒有權限  
  8.     resumeConnection.setRequestProperty("Cookie", cookieVal);  
  9. }  
  10. resumeConnection.connect();  
  11. InputStream urlStream = resumeConnection.getInputStream();  
  12. BufferedReader bufferedReader = new BufferedReader(  
  13.         new InputStreamReader(urlStream));  
  14. String ss = null;  
  15. String total = "";  
  16. while ((ss = bufferedReader.readLine()) != null) {  
  17.     total += ss;  
  18. }  
  19. IOUtils.write(total, new FileOutputStream("d:/index.html"));  
  20. bufferedReader.close();  

       通過上述方式,就能訪問帶有權限控制的URL了。思路即為:模擬登陸,取得cookie以記錄身份,下次請求時發送cookie以表明身份。

轉自:http://blog.csdn.net/prince2270/article/details/6137810


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM