[引用]java模拟游览器进行post和get

  使用HttpURLConnection发送post和get请求

1、http://blog.csdn.net/pandazxx/archive/2007/06/18/1657109.aspx

2、http://blog.csdn.net/pandazxx/archive/2007/06/20/1660008.aspx 

但我们常常会碰到这样一种情况:

通过HttpURLConnection来模拟模拟用户登录Web服务器,服务器使用cookie进行用户认证。在模拟登录时,Post表单数据后可以正确登录(登陆成功时会response一个cookie,然后redirect到main page,不成功则redirect到login page),但是在使用HttpURLConnection再次连接服务器其他页面(或者即使是当前的response里是redirect的page)时,服务器都会认为是全新的一个Session。

解决方法有2步:

1. 调用HttpURLConnection (send post request to login page)的setInstanceFollowRedirects()方法,参数为false (这样不会去获取redirect page)

2. 获取HttpURLConnection send post request to login page的session id,然后在之后每一次的connection里都加上该session id

Example:

    String sessionId =  "";  
     public  static  void  sendLoginRequest()  throws  IOException {
       URL loginUrl =  new  URL( "http://xxx" );
       HttpURLConnection connection = (HttpURLConnection) loginUrl.openConnection();
 
 
        // Output to the connection. Default is
        // false, set to true because post
        // method must write something to the
        // connection
        //  设置是否向 connection 输出,因为这个是 post 请求,参数要放在
        // http 正文内,因此需要设为 true
       connection.setDoOutput( true );
        // Read from the connection. Default is true.
       connection.setDoInput( true );
        // Set the post method. Default is GET
       connection.setRequestMethod( "POST" );
        // Post cannot use caches
        // Post  请求不能使用缓存
       connection.setUseCaches( false );
 
        // This method takes effects to
        // every instances of this class.
        // URLConnection.setFollowRedirects static 函数,作用于所有的 URLConnection 对象。
        // connection.setFollowRedirects(true);
      
        // This methods only
        // takes effacts to this
        // instance.
        // URLConnection.setInstanceFollowRedirects 是成员函数,仅作用于当前函数
       connection.setInstanceFollowRedirects( false);
      
        // Set the content type to urlencoded,
        // because we will write
        // some URL-encoded content to the
        // connection. Settings above must be set before connect!
        //  配置本次连接的 Content-type ,配置为 application/x-www-form-urlencoded
        //  意思是正文是 urlencoded 编码过的 form 参数,下面我们可以看到我们对正文内容使用 URLEncoder.encode
        //  进行编码
       connection.setRequestProperty( "Content-Type" ,
               "application/x-www-form-urlencoded" );
        //  连接,从 postUrl.openConnection() 至此的配置必须要在 connect 之前完成,
        //  要注意的是 connection.getOutputStream 会隐含的进行 connect
       connection.connect();
 
       DataOutputStream out =  new  DataOutputStream(connection
              .getOutputStream());
 
          // 要传的参数
       String content = URLEncoder.encode( "username""UTF-8") + "="
              + URLEncoder.encode("XXX""UTF-8");
       content += "&" + URLEncoder.encode("password""UTF-8") + "="
              + URLEncoder.encode("XXXX""UTF-8");
 
        // DataOutputStream.writeBytes 将字符串中的 16 位的 unicode 字符以 8 位的字符形式写道流里面
       out.writeBytes(content);
 
       out.flush();
       out.close();  // flush and close
 
           //Get Session ID
       String key =  "" ;
        if (connection != null) {
           for (int i = 1; (key = connection.getHeaderFieldKey(i)) != null; i++) {
               if (key.equalsIgnoreCase("set-cookie")) {
                  sessionId = connection.getHeaderField(key);
                  sessionId = sessionId.substring(0, sessionId.indexOf( ";"));
              }
           }
       }     
       connection.disconnect();
    }
 

 然后之后每一次connection都要加上这个session id:

URL url = new URL("http:......");
HttpURLConnection connection = (HttpURLConnection)url.openConnection();
connection.setRequestProperty("Cookie",this.sessionId);
connection.connect();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值