自动化测试中的验证码处理

2021-08-24 11:40发布

在日常的测试过程中避免不了要遇到登录的测试,但是在登录时又常常遇到验证码,那么该如何跳过验证码,直接自动登录呢?

     当前在市面上比较流行的方式有:

(1)直接跳过验证码(测试环境中:让开发将验证码部分注释掉)。

(2)写生万能验证码(测试环境或准生产环境中:让开发将验证码写成固定的验证码)

(3)通过图像技术进行识别(依赖于相关图像识别技术,针对复杂的情况识别不准)

(4)利用cookie 跳过验证码

     那么我们就来介绍下最后一种利用cookie跳过验证码技术。

     首先,什么是cookie?

Cookie是一个保存在客户机中的简单的文本文件, 这个文件与特定的 Web 文档关联在一起, 保存了该客户机访问这个Web 文档时的信息, 当客户机再次访问这个 Web 文档时这些信息可供该文档使用。

例如, 一个 Web 站点可能会为每一个访问者产生一个唯一的ID, 然后以 Cookie 文件的形式保存在每个用户的机器上。如果使用浏览器访问 Web, 会看到所有保存在硬盘上的 Cookie相当于,用户首次登录时,服务器端就生成了一个唯一的验证信息,然后再将该验证信息发送给客户端,这样这个信息就是cookie,相当于一个身份验证,当用户在进行第二次登录时,就使用已有的如上的cookie进行登录就可以了。从而实现自动登录。

     其次,自动化测试中常用的获取及添加cookie的方法

get_cookie(key):获取指定cookie

get_cookies():获取所有cookie

add_cookie({key:value})  :添加cookie,一定要注意格式,字典形式

 

 

     再次,常见问题如下:

问题一:

driver.add_cookie()中参数填写错误,导致脚本执行失败

 

解决方案:

driver.add_cookie()中参数需要是字典形式,如下

 

 

问题二:

添加完cookie()后,页面显示不正确,无反应

 

解决方案:

需要在添加完cookie()后,刷新页面,如下

 

问题三:

执行脚本进行自动登录时,发现脚本已执行完成,但是网页依然没有登录成功。

1)脚本执行成功

 

现象:页面仍然是登录页面

解决方案:

需要在自动化测试前,提前将需要登录的用户进行登录

备注:每次登录时用户的cookie都可能发生变化,所以重新登录时,需要获取新的cookie值,更新到最新的脚本中。