zoukankan      html  css  js  c++  java
  • WebBowser 实现淘宝网自动登录

    游戏外挂 登录是第一步,我想自动挂的是 淘宝上的 游戏,所以首先 自动登录淘宝。淘宝网是加密的,安全控件登录。用底层的收发包技术做,解密有难度。

        我的思路是用c#做个软件完全模拟鼠标键盘操作,你平时怎么操作,程序就怎么模拟。OK,按照这个思路做下去。

    首先是用c#中的WebBrowser控件打开登录网页,很简单,拖拽WebBrowser到Form上,然后给它的Url属性赋值。WebBrowser就会自动navigate to 这个网页。

    WebBrowser1.Url= new Uri("淘宝网登录地址")

    HtmlElement usrname=WebBrowser1.Document.GetElementById("ID值"), 这条语句可获得用户名输入框元素。ID值可以通过查看HTML源文件得到。还有很多方法可以找到该元素,看msdn就可以了。

    usrname.Focus(); 将输入焦点定位到用户名输入框上。

    下面就是用System.Windows.Forms.SendKeys.Send()方法模拟键盘操作输入用户密码并回车:

    System.Windows.Forms.SendKeys.Send("UserName"); 
    System.Windows.Forms.SendKeys.Send("{tab}"); //输入tab键,输入焦点定位到了密码输入框
    System.Windows.Forms.SendKeys.Send("password"); //模拟键盘输入密码
    System.Windows.Forms.SendKeys.Send("{enter}");

          有个难点就是,Webbrowser导航到一个URL的时候,需要时间,如果网页复杂,时间会比较长。如果将Url属性赋值之后,立刻就去查找用户名输入框元素的话,会找不到。所以我们的代码要在加载完成后执行。微软的帮助上说DocumentCompleted事件发生在文件加载完成时,我想把代码放到这个事件里。实际上并非完全如帮助描述,在加载一个Url到完成的时候,DocumentCompleted事件也会发生很多次。一般最后一次才是真正加载完成。解决办法一是结合ReadyState判断,当ReadyState也是completed的时候作为加载完成标志。另外一种是启用Flag,代码中依据判断flag值执行不同的功能。每打开一个新的URL之后,每次DocumentCompleted事件都查找,直到找到了我们想要的元素,执行键盘输入模拟代码,然后修改flag标志。这种方法当打开的Url多的时候容易弄乱,建议画个状态图。

    例子:

    Int flag=0

    private void webBrowser1_DocumentCompleted(object sender, WebBrowserDocumentCompletedEventArgs e)

    {

    if (flag==0)

    {

    HtmlElement usrname=WebBrowser1.Document.GetElementById("ID值"),

    if (usrname!=null)

    {

    usrname.Focus(); 将输入焦点定位到用户名输入框上。

    System.Windows.Forms.SendKeys.Send("UserName"); System.Windows.Forms.SendKeys.Send("{tab}"); //输入tab键,输入焦点定位到了密码输入框 System.Windows.Forms.SendKeys.Send("password"); //模拟键盘输入密码 System.Windows.Forms.SendKeys.Send("{enter}");

    flag=1;

    }

    }

    }
  • 相关阅读:
    fcc的高级算法题
    jq on方法绑定多个事件
    高效的jQuery代码编写技巧
    HTML 提高页面加载速度的方法
    link 和 import 导入外部样式的区别
    js将多个方法添加到window对象上的多种方法
    js 数组删去重复的加上没有的元素
    JS中定义对象原型的两种使用方法
    CSS 清除默认样式
    JavaScript中定义对象的四种方式 2012-5-10 15:19 阅读(0)
  • 原文地址:https://www.cnblogs.com/wangchunming/p/2289628.html
Copyright © 2011-2022 走看看