欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android利用爬蟲實(shí)現(xiàn)模擬登錄的實(shí)現(xiàn)實(shí)例

 更新時(shí)間:2017年09月13日 10:58:11   作者:_Yasin  
這篇文章主要介紹了Android利用爬蟲實(shí)現(xiàn)模擬登錄的實(shí)現(xiàn)實(shí)例的相關(guān)資料,希望通過本文能幫助到大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下

Android利用爬蟲實(shí)現(xiàn)模擬登錄的實(shí)現(xiàn)實(shí)例

為了用手機(jī)登錄校網(wǎng)時(shí)不用一遍一遍的輸入賬號(hào)密碼,于是決定用爬蟲抓取學(xué)校登錄界面,然后模擬填寫本次保存的賬號(hào)、密碼,模擬點(diǎn)擊登錄按鈕。實(shí)現(xiàn)過程折騰好幾個(gè)。

一開始選擇的是htmlunit解析登錄界面html,在pc上測的能實(shí)現(xiàn),結(jié)果在android上運(yùn)行不起來,因?yàn)閔tmlunit利用了javax中的類實(shí)現(xiàn)的解析,android不支持javax,所以就跑不起來。

不過pc還是ok的

實(shí)例代碼:

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 對(duì)css和javascript的支持不好,所以請關(guān)閉之
      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("/*填寫你的賬號(hào)*/");
      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());
    }

  }
}

于是接著調(diào)研,發(fā)現(xiàn)利用jsoup可以在android運(yùn)行起來,不過這個(gè)庫能抓取網(wǎng)頁中的內(nèi)容,也能進(jìn)行賦值操作,但不支持模擬點(diǎn)擊事件,網(wǎng)上有好多例子,是利用第一次訪問獲取cookie,然后把賬號(hào)密碼再給Post到服務(wù)器,完成模擬登陸??梢晕覀兊男>W(wǎng)竟然沒有使用cookie,于是我只能抓包看看post的data有什么,然后把data直接通過post發(fā)送,不過不知道我們校網(wǎng)密碼的加密的方式,所以填寫密碼需要先去抓包,抓到自己賬號(hào)的密文,然后放到data中直接發(fā)送。成功了!

核心代碼:

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();//獲取響應(yīng)
    Document doc = Jsoup.parse(rs.body());

    datas.put("DDDDD", "/*自己的賬號(hào)*/");
    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");
     //設(shè)置cookie和post上面的map數(shù)據(jù).cookies(rs.cookies())
    Response login=con2.ignoreContentType(true).method(Method.POST).data(datas).execute();

    Message msg = new Message();
    msg.what = 1;
    mHandler.sendMessage(msg);


  }

抓包方式:

點(diǎn)擊登錄后快速停止監(jiān)聽,獲取form data,然后把data中的值填上就好了。

總的來說,如果只是單純抓取網(wǎng)頁內(nèi)容android這一塊利用jsoup還是能實(shí)現(xiàn)的,但不支持按鈕的點(diǎn)擊操作;Htmlunit API更好用,也能模擬點(diǎn)擊事件,不過javax android并不支持,但服務(wù)器還是可以用來抓取數(shù)據(jù)的。

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

最新評(píng)論