源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Android模拟登录评论CSDN实现代码

  • 时间:2021-01-04 20:12 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Android模拟登录评论CSDN实现代码
有时候作为非官方开发的APP集成了官方的所有信息,但是现在需要实现另一个功能那就是登录发表评论到官方的网站,而非官方的APP并不知道官方网站是怎么实现登录与评论的,而且越大型的网站,为了防止这样的事情发生,增加了许许多多阻碍,不过我们这里可以给大家提供一个通用的方式,就是有点费时,不过按照此方法,基本所有的网站都不在话下。今天就拿CSDN做一下试验。 [b]1.登录CSDN [/b] 查看其源代码看看其form表单: [img]http://files.jb51.net/file_images/article/201611/2016112104400512.png?2016102104410[/img] 其难点在post data数据中it的value与execution的value,其为随机产生,这估计是CSDN防止恶意登录设置的动态标识,不过你可以在Android 中先获取该值然后设置到需要提交的表单项中。 下面使用xutils与Jsoup获取网页属性:
RequestParams params = new RequestParams("https://passport.csdn.net/account/login?ref=toolbar");
params.setHeader("User-Agent","Mozilla/5.0 (Windows NT 6.1; Trident/7.0; rv:11.0) like Gecko");
x.http().get(params, new Callback.CommonCallback<String>() {
  @Override
  public void onSuccess(String result) {
    Log.i("csdn", "onSuccess");
    RequestParams params1=new RequestParams("https://passport.csdn.net/account/login?ref=toolbar");
    params1.setHeader("Accept","text/html, application/xhtml+xml, */*");
    params1.setHeader("Content-Type", "application/x-www-form-urlencoded");
    params1.setHeader("DNT", "1");
    params1.setHeader("Host","passport.csdn.net");
    params1.setHeader("Accept-Language","zh-CN");
    params1.setHeader("User-Agent","Mozilla/5.0 (Windows NT 6.1; Trident/7.0; rv:11.0) like Gecko");
    Document doc=Jsoup.parse(result);
    Element formEle=doc.getElementById("fm1");
    Elements inputs=formEle.getElementsByTag("input");
    for (Element input : inputs){
      if(input.attr("name").equals("lt")){
        params1.addQueryStringParameter("lt", input.attr("value"));
      }else if(input.attr("name").equals("execution")){
        params1.addQueryStringParameter("execution", input.attr("value"));
      }else if(input.attr("name").equals("_eventId")){
        params1.addQueryStringParameter("_eventId", input.attr("value"));
      }
    }
    params1.addQueryStringParameter("username", "你的帐号");
    params1.addQueryStringParameter("password","你的密码");
  }

  @Override
  public void onError(Throwable ex, boolean isOnCallback) {
    Log.i("csdn", "onError");
  }

  @Override
  public void onCancelled(CancelledException cex) {
    Log.i("csdn", "onCancelled");
  }

  @Override
  public void onFinished() {
    Log.i("csdn", "onFinished");
  }
});

这样我们不仅获取了网页的动态标识,而且设置到即将提交表单的RequestParams当中。 这样我们重新生成了一个params1,这个时候所有表单信息都已经设置到其中,下面就就模拟登录了:
public void getLoginCSDN(final RequestParams params){
  x.http().request(HttpMethod.POST, params, new Callback.CommonCallback<String>() {
    @Override
    public void onSuccess(String result) {
      Log.i("liyuanjinglyj", "onSuccess");
      System.out.println(result.toString());

    }

    @Override
    public void onError(Throwable ex, boolean isOnCallback) {
      ex.printStackTrace();
      Log.i("liyuanjinglyj", "onError");
    }

    @Override
    public void onCancelled(CancelledException cex) {
      Log.i("liyuanjinglyj", "onCancelled");
    }

    @Override
    public void onFinished() {
      Log.i("liyuanjinglyj", "onFinished");
    }
  });

调用getLoginCSDN将在日志中输出如下信息: [img]http://files.jb51.net/file_images/article/201611/2016112104321887.png?2016102104336[/img] 2.评论CSDN博文 首先我们随便打开一篇博文,将httpWatch也打开。现在在评论中输入信息,不要立即点击提交,先开启httpWatch。然后提交,然后关闭,我们会得到如下界面:[img]http://files.jb51.net/file_images/article/201611/2016112104525009.png?2016102104535[/img] 这里提交的表单数据为三个,还有一个Query String:[img]http://files.jb51.net/file_images/article/201611/2016112104551747.png?2016102104610[/img] 这里为什么不打开HTML代码看,那我们先看看HTML代码: [img]http://files.jb51.net/file_images/article/201611/2016112104629885.png?2016102104638[/img] 能看出什么吗?我唯一看出来的就是表单在div id=comment_form中,可是提交的表单项去哪里呢?答案就是CSDN写在JS里面了。下面我们打开其处理comment_form的JS。 [img]http://files.jb51.net/file_images/article/201611/2016112104655375.png?201610210476[/img] 人家写在这里,你不费点时间还真找不到。如果你按照JS里面的name提交表单数据,那么你肯定得不到任何结果。返回0以失败结束。 下面我们开始设置评论的相关数据到RequestParams中:
RequestParams requestParams = new RequestParams("http://blog.csdn.net/ljy1988123/comment/submit");
requestParams.setConnectTimeout(15000);
requestParams.setHeader("User-Agent", "Mozilla/5.0 (Windows NT 6.1; Trident/7.0; rv:11.0) like Gecko");
requestParams.setHeader("Accept-Language", "zh-CN");
requestParams.setHeader("Host","blog.csdn.net");
requestParams.setHeader("Referer","http://blog.csdn.net/ljy1988123/article/details/50581207");
requestParams.setHeader("Accept", "*/*");
requestParams.setHeader("Content-Type", "application/x-www-form-urlencoded");
requestParams.setHeader("X-Requested-With", "XMLHttpRequest");
requestParams.setHeader("Connection", "Keep-Alive");
requestParams.setMultipart(true);
requestParams.addQueryStringParameter("id", "50581207");
requestParams.addParameter("commentid", " ");
requestParams.addParameter("content", "  太喜欢这篇博文了。。 98 ");
requestParams.addParameter("replyId", " ");
setHttpContent(requestParams);
当然这里面的数据有的并不需要,为了测试我按照HttpWatch中给的设置的: [img]http://files.jb51.net/file_images/article/201611/2016112104735830.png?2016102104745[/img] 然后在调用post请求:
public void setHttpContent(RequestParams params){
  x.http().post(params, new Callback.CommonCallback<String>() {
    @Override
    public void onSuccess(String result) {
      Log.i("liyuanjinglyj", "onSuccess");
      System.out.println(result.toString());
    }

    @Override
    public void onError(Throwable ex, boolean isOnCallback) {
      ex.printStackTrace();
      Log.i("liyuanjinglyj", "onError");
    }

    @Override
    public void onCancelled(CancelledException cex) {
      Log.i("liyuanjinglyj", "onCancelled");
    }

    @Override
    public void onFinished() {
      Log.i("liyuanjinglyj", "onFinished");
    }
  });
}

将输出如下日志信息: [img]http://files.jb51.net/file_images/article/201611/2016112104811852.png?2016102104821[/img] 其返回1代表成功,返回0代表失败,唯一需要说明的是我设置的超时时间是15秒,为什么设置这么长时间,想必大家比我清楚,CSDN在网页评论都需要这么长时间,何况手机端呢。 在看看网页效果:[img]http://files.jb51.net/file_images/article/201611/2016112104834260.png?2016102104848[/img] 多的一个是测试中超时报错发表上去的。 这篇文章只是模拟的登录与评论CSDN,其他网站与这差不多。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部