51Testing软件测试论坛

标题: web 测试中绕开验证码登陆的方式 [打印本页]

作者: 小爸爸    时间: 2017-5-31 15:06
标题: web 测试中绕开验证码登陆的方式
web自动化测试中让测试者感到困惑的是登陆验证码,每次都不一样。现在推荐一种绕开验证码登陆的方式,其实就是将web浏览器获取的登陆cookie加载到程序中就可以了,这样程序就会认为你已经登陆,就可以跳过登录的操作了。具体代码如下:

  1. private static void getLogin(String url,String cookie,WebDriver driver){
  2.     driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);
  3.     driver.get(url);  // 需手动访问一次测试页面获得cookie
  4.     driver.manage().deleteAllCookies();   // 删除cookie里的内容
  5.     Cookie ck = new Cookie("PHPSESSID", cookie);   // 初始化已经保存了登录信息的cookie
  6.     driver.manage().addCookie(ck);  // webdriver添加cookie
  7.     driver.get(url);   // 访问后就会发现已经登录成功了
  8.     //driver.manage().window().maximize();  //将浏览器最大化
  9.     driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);;
  10.     Set<Cookie> cookies = driver.manage().getCookies();
  11.     System.out.println(String.format("Domain -> name -> value -> expiry -> path"));
  12.     for (Cookie c : cookies)
  13.         System.out.println(String.format("%s -> %s -> %s -> %s -> %s", c.getDomain(), c.getName(), c.getValue(),c.getExpiry(), c.getPath()));
  14. }
复制代码


作者: 测试就是来开荒    时间: 2017-6-5 17:11
如果cookie过期了就没辙了。。
作者: 测试就是来开荒    时间: 2017-6-5 17:12
这个怎么弄的 我不会啊,楼主能否给一个稍微完整的示例代码参考一下,谢谢!




欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2