Httpclient模拟登入

           用 HttpClient进行请求与响应的例子。表示创建一个客户端, 相当于打开浏览器。 使用 get方式http://www.hsuncloud.com/AttendanceManage/AttMonthReport进行请求。 执行请求httpclient.executeMethod
(),获取响应状态。第四行的 getMethod.getResponseBodyAsString()方法能够以字符串方式获取返回的内容。这

也是网页抓取所需要的内容。



import java.io.File;

import java.io.FileOutputStream;
import java.util.ArrayList;
import java.util.List;


import org.apache.commons.httpclient.Cookie;  
import org.apache.commons.httpclient.HttpClient;  
import org.apache.commons.httpclient.cookie.CookiePolicy;  
import org.apache.commons.httpclient.NameValuePair;  
import org.apache.commons.httpclient.methods.GetMethod;  
import org.apache.commons.httpclient.methods.PostMethod;  
import org.apache.http.message.BasicNameValuePair;


/**  
 * @author 作者 :My_virus 
 */  
public class HttpClientLogin {  
  
    public static void main(String[] args) {  
        // 登陆 Url  
        String loginUrl = "http://www.hsuncloud.com/Account/LogOn";  
        // 需登陆后访问的 Url  
        String dataUrl = "http://www.hsuncloud.com/AttendanceManage/AttMonthReport";  
  
        HttpClient httpClient = new HttpClient();  
  
        // 模拟登陆,按实际服务器端要求选用 Post 或 Get 请求方式  
        PostMethod postMethod = new PostMethod(loginUrl);  
  
        // 设置登陆时要求的信息,用户名和密码  
        NameValuePair[] data = { new NameValuePair("MobileNumber", "**********"),  
                new NameValuePair("Password", "*******") };  
        postMethod.setRequestBody(data);  
        try {  
            // 设置 HttpClient 接收 Cookie,用与浏览器一样的策略  
            httpClient.getParams().setCookiePolicy(CookiePolicy.BROWSER_COMPATIBILITY);
            //登入操作
            httpClient.executeMethod(postMethod);  
            
            // 获得登陆后的 Cookie  
            Cookie[] cookies = httpClient.getState().getCookies();  
            StringBuffer tmpcookies = new StringBuffer();  
            for (Cookie c : cookies) { 
            //打印ASP.NET_SessionId
            System.out.println(c.toString());
                tmpcookies.append(c.toString() + ";");  
            }  
            
            
            //带着登录过的cookie请求下一个页面,可以是需要登录才能到达的createurl
            
            
            //第一步:生成报表请求
            String createurl="http://www.hsuncloud.com/AttendanceManage/AttMonthReport/3";
            PostMethod post = new PostMethod(createurl);
            // 每次访问需授权的网址时需带上前面的 cookie 作为通行证 
            post.setRequestHeader("cookie", tmpcookies.toString());
            //例如,referer 从哪里来的,从我登入的进来后的第一个起始页面来的
postMethod.setRequestHeader("Referer", "http://www.hsuncloud.com/");
            
postMethod.setRequestHeader("User-Agent", "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:47.0) Gecko/20100101 Firefox/47.0"); 
            //执行请求操作
int StatusCode=httpClient.executeMethod(post);
            //打印状态码
            System.out.println("生成报表"+StatusCode);
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
    }  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值