zoukankan      html  css  js  c++  java
  • Java模拟登陆02【转载】

         在使用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

  • 相关阅读:
    SQL注入
    mysq笔记
    白话内存管理(一):从开国大典说起
    【转载】光纤协议中 WWPN 编码规则及实例解析
    利用django打造自己的工作流平台(三):任务的批量分派和跟踪
    利用django打造自己的工作流平台(二):疫情统计系统
    利用django打造自己的工作流平台(一):从EXCEL到流程化运作
    驾驭git merge——git merge的规范化操作
    一款用于绘制状态机转换图和流程图的web在线绘图工具
    利用python+graphviz绘制数据结构关系图和指定目录下头文件包含关系图
  • 原文地址:https://www.cnblogs.com/dekevin/p/3581394.html
Copyright © 2011-2022 走看看