HttpClient 模拟登录Web版新浪微博
- - zzm其中密码部分进行了加密,加密的算法在网页的js文件里,网上有人把它改成了Java代码. 下面是SinaSSoEncoder类:. 转:http://www.cnblogs.com/e241138/archive/2012/09/16/2687124.html. 已有 0 人发表留言,猛击->> 这里<<-参与讨论.
我们要做的就是获取服务器需要的数据,然后用HttpClient模拟浏览器提交。
有几点需要说明一下:
go标签内的href是我们第二次请求的地址,通过这个地址来获取cookie。
用户密码那个field的name属性是随机变化的,需要先获取它然后提交。
下面是整个源代码。
思路:先获取表单的值,然后用POST方法提交。注意添加RequestHeader信息,否则会被服务器拒绝(403)。
/** * 获取手机版微博的cookies * @param username * 微博用户名 * @param password * 微博密码 * @return Cookie[] */ public Cookie[] getMCookies(String username, String password){ Cookie[] cookies = null; HttpClient client; PostMethod post = null; try{ Document doc = Jsoup.connect("http://3g.sina.com.cn/prog/wapsite/sso/login.php").get(); Elements elements = doc.getElementsByTag("postfield"); String randUrl = doc.getElementsByTag("go").first().attr("href"); String pwName = elements.get(1).attr("name"); String vkValue = elements.get(2).attr("value"); String backURL = elements.get(4).attr("value"); String backTitle = elements.get(5).attr("value"); String url = "http://3g.sina.com.cn/prog/wapsite/sso/"+randUrl; post = new PostMethod(url); post.setRequestHeader("User-Agent","Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.1 (KHTML, like Gecko) Chrome/21.0.1180.77 Safari/537.1"); post.setRequestHeader("Referer", "http://weibo.com/"); post.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); post.setParameter("mobile", username); post.setParameter(pwName,password); post.setParameter("vk", vkValue); post.setParameter("remember", "on"); post.setParameter("backURL", backURL); post.setParameter("backTitle", backTitle); post.setParameter("submit", "1"); client = new HttpClient(); client.executeMethod(post); cookies = client.getState().getCookies(); }catch(IOException e){ e.printStackTrace(); }finally{ post.abort(); } return cookies; }
如果用户名密码正确的话,应该就可以获得cookie了。
接下来如果想要访问某些网页只需要带上cookie就行了。
由于新浪的网页可能会变化,所以不保证此方法一直能用,不过大体思路应该是不会变的。
转:http://www.cnblogs.com/e241138/archive/2012/09/16/2687120.html