zoukankan      html  css  js  c++  java
  • 用c#中的WebBrowser抢小米F码,抢小米手机以及自动测试实现原理

    首先是用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;
          }
      }
    }
  • 相关阅读:
    关于JS中判断两个数组相等
    用JS实现二叉树
    elementUI select组件 默认选择第一项
    angular [src] 绑定url或src 报XSS错误
    easy-mock本地搭建工程实操
    array splice split || string split slice 傻傻分不清楚=>终于弄清楚了
    循环=>轮回=>js循环比拼
    vue-cli 搭建工程配置 => 你想要这里都有
    git分支问题 查看、创建、关联、删除本地/远程分支
    vue知识点 && 错误点 => 持续更新
  • 原文地址:https://www.cnblogs.com/vjiedao/p/3557588.html
Copyright © 2011-2022 走看看