【自动化测试验证码处理】如何跳过验证码,直接自动登录呢?

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

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

(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值,更新到最新的脚本中。


以下是我收集到的比较好的学习教程资源,虽然不是什么很值钱的东西,如果你刚好需要,可以评论区,留言【777】直接拿走就好了

各位想获取资料的朋友请 点赞 + 评论 + 收藏 ,三连!

三连之后我会在评论区挨个私信发给你们~

相关推荐
代码搬运媛6 小时前
Jest 测试框架详解与实现指南
前端
counterxing7 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq7 小时前
windows下nginx的安装
linux·服务器·前端
之歆7 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜8 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108088 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
kyriewen9 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm10 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy10 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
德思特10 小时前
通过 Wireshark 抓取串口命令
网络协议·测试工具·wireshark