news 2026/6/15 17:58:03

自动化测试中验证码问题如何解决?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
自动化测试中验证码问题如何解决?

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

经常会被问到如何解决验证码的问题,在此记录一下我所知道的几种方式。

对于web应用来说,大部分的系统在用户登录时都要求用户输入验证码,验证码的类型的很多,有字母数字的,有汉字的,甚至还要用户输入一条算术题的答案的,对于系统来说使用验证码可以有效果的防止采用机器猜测方法对口令的刺探,在一定程度上增加了安全性。但对于测试人员来说,不管是进行性能测试还是自动化测试都是一个棘手的问题。

下面来谈一下处理验证码的几种方法。

去掉验证码

这是最简单的方法,对于开发人员来说,只是把验证码的相关代码注释掉即可,如果是在测试环境,这样做可省去了测试人员不少麻烦,如果自动化脚本是要在正式环境跑,这样就给系统带来了一定的风险。

设置万能码

去掉验证码的主要是安全问题,为了应对在线系统的安全性威胁,可以在修改程序时不取消验证码,而是程序中留一个“后门”---设置一个“万能验证码”,只要用户输入这个“万能验证码”,程序就认为验证通过,否则按照原先的验证方式进行验证。

#coding=utf-8 import random #生成0到10之间的随机数 #d = random.uniform(0,10) #print d #生成一个1000到9999之间的随机整数 d = random.randint(1000,9999) print u"生成的随机数:%d " %d i = input(u"请输入随机数:") print i if i == d: print u"登录成功!!" elif i == 1111: print u"登录成功!!" else: print u"请重新输入验证码!"

运行结果:

>>> ================================ RESTART ================================ >>> 生成的随机数:3764 请输入随机数:1111 1111 登录成功!! >>> ================================ RESTART ================================ >>> 生成的随机数:3763 请输入随机数:3763 3763 登录成功!! >>> ================================ RESTART ================================ >>> 生成的随机数:1928 请输入随机数:1354646 1354646 请重新输入验证码!

random

random用于生成随机数

randint()

randint()方法用于生成随机整数,传递的两个参数分别是随机数的范围,randint(1000,9999)第二个参数要大于第一个参数。

我们要求用户输入随机数,并且对用户输入做判断,如果等于生成的随机数那么,登录成功,如果等于1111也算登录成功,否则失败。那么等于1111的判断就是一个万能码。

验证码识别技术

例如可以通过Python-tesseract 来识别图片验证码,Python-tesseract是光学字符识别Tesseract OCR引擎的Python封装类。能够读取任何常规的图片文件(JPG, GIF ,PNG , TIFF等)。不过,目前市面上的验证码形式繁多,目前任何一种验证码识别技术,识别率都不是100% 。

记录cookie

(适用于UI自动化测试,且目前在大部应用的用户名密码不记录在cookie 或 进行加密处理。)

通过向浏览器中添加cookie 可以绕过登录的验证码,这是比较有意思的一种解决方案。我们可以在用户登录之前,通过add_cookie()方法将用户名密码写入浏览器cookie ,再次访问系统登录链接将自动登录。例如下面的方式:

.... #访问xxxx网站 driver.get("http://www.xxxx.cn/") #将用户名密码写入浏览器cookie driver.add_cookie({'name':'Login_UserNumber', 'value':'username'}) driver.add_cookie({'name':'Login_Passwd', 'value':'password'}) #再次访问xxxx网站,将会自动登录 driver.get("http://www.xxxx.cn/") time.sleep(3) .... driver.quit()

使用cookie进行登录最大的难点是如何获得用户名密码的name ,如果找到不到name 的名字,就没办法向value 中输用户名、密码信息。

我建议是可以通过get_cookies()方法来获取登录的所有的cookie信息,从而进行找到用户名、密码的name 对象的名字;当然,最简单的方法还是询问前端开发人员。

总结

最简单安全,行之有效的方式就是设置万能码,稍微和开发沟通一下就OK了。如果乐于“闷头苦干自力更生”的话也可研究验证码识别技术。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 15:22:43

Jupyter Notebook集成Bokeh实现TensorFlow大数据可视化

Jupyter Notebook集成Bokeh实现TensorFlow大数据可视化 在深度学习项目中,模型训练往往像一场“盲跑”:你设置了超参数、启动了训练流程,然后只能盯着日志文件里不断跳动的数字,猜测模型是否在收敛。尤其是在处理大规模数据集或复…

作者头像 李华
网站建设 2026/6/15 14:09:53

揭秘C++26静态反射机制:如何在编译期实现类型自省与代码生成

第一章:C26静态反射机制概述C26 引入的静态反射机制旨在在编译期提供对类型、成员和属性的元数据访问能力,无需运行时开销即可实现通用编程模式。该机制允许开发者通过标准库接口直接查询类的结构信息,例如字段名、函数签名和继承关系&#x…

作者头像 李华
网站建设 2026/6/15 14:19:08

LJ640U34工业液晶显示屏

LJ640U34 工业液晶显示屏主要特点如下:核心用途用于工业环境中显示设备状态、操作界面或系统数据,适合人机界面(HMI)应用。可承受工业现场的振动、温度和灰尘等恶劣条件。产品特点显示性能高分辨率液晶屏,图像清晰、色…

作者头像 李华
网站建设 2026/6/15 13:56:01

错过将淘汰!KubeEdge边云协同Java开发的7个前沿趋势

第一章:KubeEdge边云协同Java开发的变革与机遇随着物联网与边缘计算的快速发展,KubeEdge 作为首个开源的 Kubernetes 原生边缘计算平台,正在重塑边云协同的技术架构。其核心价值在于将 Kubernetes 的容器编排能力无缝延伸至边缘节点&#xff…

作者头像 李华
网站建设 2026/6/15 14:04:35

【C++26静态反射元编程实战】:掌握下一代C++黑科技的5大核心技巧

第一章:C26静态反射元编程概述C26 正在将静态反射(Static Reflection)作为核心语言特性之一引入,旨在为开发者提供在编译期获取和操作类型信息的能力,而无需依赖复杂的模板元编程技巧。这一机制允许程序在不运行时开销…

作者头像 李华
网站建设 2026/6/15 13:49:19

【企业级Java开发规范】:为什么你的类文件管理总是出错?

第一章:Java模块化类文件管理的核心理念Java模块化类文件管理是Java 9引入的模块系统(JPMS, Java Platform Module System)的核心组成部分,旨在解决传统classpath机制下的“JAR地狱”问题。通过显式声明模块间的依赖关系&#xff…

作者头像 李华