<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    qileilove

    blog已經轉移至github,大家請訪問 http://qaseven.github.io/

    自動化測試如何解決驗證碼的問題

    下面摘錄別人的 當然有好的一面 有差的一面  好的一面 我們認識了 解決驗證碼最基礎的幾種方法 其實不叫解決  只能算是避過驗證碼 真正的驗證碼識別 需要用的很多技術  圖像識別 源碼分析,網絡數據流等等 起碼我辦不到 做自動化的話 還要什么驗證碼 我覺得如果你驗證碼只是為了防止防止用戶誤操作 或者 防止某些刷子 減少服務器的壓力 而設置的  如果真的是為了自動化測試 我們完全可以屏蔽改功能 要他干嘛 。

    注意:本標題的“自動化測試” 包括性能測試 與UI級的自動化測試

      經常會被問到如何解決驗證碼的問題,在此記錄一下我所知道的幾種方式。

      對于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了。如果樂于“悶頭苦干自力更生”的話也可研究驗證碼識別技術。

    posted on 2014-04-08 11:13 順其自然EVO 閱讀(1232) 評論(0)  編輯  收藏 所屬分類: 自動化測試python

    <2025年7月>
    293012345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    導航

    統計

    常用鏈接

    留言簿(55)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 久久久国产亚洲精品| 1000部拍拍拍18勿入免费凤凰福利| 亚洲av无码无在线观看红杏| 久久亚洲精品成人| 福利免费观看午夜体检区| 美女视频黄频a免费| 亚洲日韩一页精品发布| 5555在线播放免费播放| 亚洲av色福利天堂| 亚洲国产精品第一区二区三区| 97久久精品亚洲中文字幕无码| 国产免费小视频在线观看| 国产精成人品日日拍夜夜免费| 亚洲sm另类一区二区三区| 亚洲伦理一二三四| 亚洲av午夜福利精品一区| 国产91精品一区二区麻豆亚洲| 毛片a级毛片免费播放100| 亚洲人成网男女大片在线播放| 国产精品色拉拉免费看| 亚洲成人黄色在线| 四虎影永久在线高清免费| 在线观看人成视频免费| 成人免费无码大片A毛片抽搐| 色窝窝免费一区二区三区| 亚洲人成精品久久久久| 亚洲国产精品高清久久久| 99re在线这里只有精品免费 | 青草久久精品亚洲综合专区| 成人片黄网站色大片免费| 日韩毛片无码永久免费看| 亚洲AV无码片一区二区三区| 国产精品亚洲一区二区三区在线| 亚洲黄色中文字幕| 日韩在线播放全免费| 精品国产免费一区二区| 亚洲人成影院在线无码按摩店| 亚洲无线电影官网| 在线观看亚洲电影| 777亚洲精品乱码久久久久久| 伊人久久五月丁香综合中文亚洲|