51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 1560|回复: 3
打印 上一主题 下一主题

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

[复制链接]
  • TA的每日心情
    擦汗
    2018-3-20 09:57
  • 签到天数: 33 天

    连续签到: 1 天

    [LV.5]测试团长

    跳转到指定楼层
    1#
    发表于 2017-11-27 11:39:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    本帖最后由 NewDreamTester 于 2017-11-27 11:42 编辑

    注意:本标题的“自动化测试” 包括性能测试 与UI级的自动化测试

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

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

    1、去掉验证码

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

    2、设置万能码

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

    #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的判断就是一个万能码。

    3、验证码识别技术

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

    4、记录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 对象的名字;当然,最简单的方法还是询问前端开发人员。

    参考:自动化测试 -- 通过Cookie跳过登录验证码

    总结:

        最简单安全,行之有效的方式就是设置万能码,稍微和开发沟通一下就OK了。如果乐于“闷头苦干自力更生”的话也可研究验证码识别技术。
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    昨天 08:43
  • 签到天数: 1667 天

    连续签到: 5 天

    [LV.Master]测试大本营

    2#
    发表于 2017-11-27 14:08:58 | 只看该作者
    验证码识别技术Python-tesseract和记录Cookie还是第一次听说这个概念,受教啦!
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-27 09:13 , Processed in 0.069051 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表