zoukankan      html  css  js  c++  java
  • java模拟Cookies登陆

    在使用java访问URL时,如果该URL需要身份验证,那么就不能够直接访问,因为没有登陆。那么,如何解决这个问题呢?

          方法是使用java模拟登陆,登陆后记录下cookie信息,在下次发起请求时时将cookie发送过去用以表明身份,这样就能够访问带有权限的URL了。

          下面首先介绍使用java模拟登陆。

    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了。

    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

  • 相关阅读:
    [PY3]——heap模块 和 堆排序
    [PY3]——求TopN/BtmN 和 排序问题的解决
    [转载+补充][PY3]——环境配置(2)——windows下安装pycharm并连接Linux的python环境
    [转载+补充]windows下SVN客户端的安装
    [Visual studio code 常见问题解决] ——中文乱码、
    Smrty模版总结(转)
    cms内容模型标签
    phpcms图文总结(转)
    phpcms总结(转)
    PHP总结
  • 原文地址:https://www.cnblogs.com/chasewade/p/3408091.html
Copyright © 2011-2022 走看看