AndroID利用爬虫实现模拟登录的实现实例
为了用手机登录校网时不用一遍一遍的输入账号密码,于是决定用爬虫抓取学校登录界面,然后模拟填写本次保存的账号、密码,模拟点击登录按钮。实现过程折腾好几个。
一开始选择的是HTMLunit解析登录界面HTML,在pc上测的能实现,结果在androID上运行不起来,因为HTMLunit利用了javax中的类实现的解析,androID不支持javax,所以就跑不起来。
不过pc还是ok的
实例代码:
package com.yasin;import java.io.IOException;import java.net.MalformedURLException;import java.net.URL;import java.util.List;import org.junit.Test;import com.gargoylesoftware.HTMLunit.browserVersion;import com.gargoylesoftware.HTMLunit.WebClIEnt;import com.gargoylesoftware.HTMLunit.HTML.HTMLForm;import com.gargoylesoftware.HTMLunit.HTML.HTMLinput;import com.gargoylesoftware.HTMLunit.HTML.HTMLPage;import com.gargoylesoftware.HTMLunit.HTML.HTMLPasswordinput;import com.gargoylesoftware.HTMLunit.HTML.HTMLsubmitinput;import com.gargoylesoftware.HTMLunit.HTML.HTMLTextinput;public class autoLogin { String url = "http://172.16.10.3/"; @Test public voID run(){ try{ WebClIEnt webClIEnt = new WebClIEnt(browserVersion.Chrome); //HTMLunit 对CSS和JavaScript的支持不好,所以请关闭之 webClIEnt.getoptions().setJavaScriptEnabled(false); webClIEnt.getoptions().setCSSEnabled(false); HTMLPage page = (HTMLPage)webClIEnt.getPage(url); List<HTMLForm> forms = page.getForms(); HTMLForm form = forms.get(0); HTMLTextinput name = form.getinputByname("ddddD"); name.setValueAttribute("/*填写你的账号*/"); HTMLPasswordinput pass = form.getinputByname("upass"); pass.setValueAttribute("/*你的密码*/"); HTMLsubmitinput ok = form.getinputByname("0MKKey"); System.out.println(pass.toString()); ok.click(); }catch(Exception e){ System.out.println(e.toString()); } }}
于是接着调研,发现利用Jsoup可以在androID运行起来,不过这个库能抓取网页中的内容,也能进行赋值 *** 作,但不支持模拟点击事件,网上有好多例子,是利用第一次访问获取cookie,然后把账号密码再给Post到服务器,完成模拟登陆。可以我们的校网竟然没有使用cookie,于是我只能抓包看看post的data有什么,然后把data直接通过post发送,不过不知道我们校网密码的加密的方式,所以填写密码需要先去抓包,抓到自己账号的密文,然后放到data中直接发送。成功了!
核心代码:
public voID login() throws IOException{ Map<String,String> datas = new HashMap<String,String>(); Connection con = Jsoup.connect("http://172.16.10.3/"); con.header("User-Agent","Mozilla/5.0 (windows NT 6.1; WOW64; rv:29.0) Gecko/20100101 firefox/29.0");//配置模拟浏览器 Response rs= con.execute();//获取响应 document doc = Jsoup.parse(rs.body()); datas.put("ddddD","/*自己的账号*/"); datas.put("upass","/*自己密码的密文,需抓包获取*/"); datas.put("R1","0"); datas.put("R2","1"); datas.put("0MMKey","123456"); System.out.println(datas.toString()); Connection con2=Jsoup.connect("http://172.16.10.3/"); con2.header("User-Agent","Mozilla/5.0 (windows NT 6.1; WOW64; rv:29.0) Gecko/20100101 firefox/29.0"); //设置cookie和post上面的map数据.cookies(rs.cookies()) Response login=con2.ignoreContentType(true).method(Method.POST).data(datas).execute(); Message msg = new Message(); msg.what = 1; mHandler.sendMessage(msg); }
抓包方式:
点击登录后快速停止监听,获取form data,然后把data中的值填上就好了。
总的来说,如果只是单纯抓取网页内容androID这一块利用Jsoup还是能实现的,但不支持按钮的点击 *** 作;HTMLunit API更好用,也能模拟点击事件,不过javax androID并不支持,但服务器还是可以用来抓取数据的。
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
总结以上是内存溢出为你收集整理的Android利用爬虫实现模拟登录的实现实例全部内容,希望文章能够帮你解决Android利用爬虫实现模拟登录的实现实例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)