下面來談一下處理驗證碼的幾種方法。
去掉驗證碼
這是最簡單的方法,對于開發人員來說,隻是把驗證碼的相關代碼注釋掉即可,如果是在測試環境,這樣做可省去了測試人員不少麻煩,如果自動化腳本是要在正式環境跑,這樣就給系統帶來了一定的風險。
設定萬能碼
去掉驗證碼的主要是安全問題,為了應對線上系統的安全性威脅,可以在修改程式時不取消驗證碼,而是程式中留一個“後門”---設定一個“萬能驗證碼”,隻要使用者輸入這個“萬能驗證碼”,程式就認為驗證通過,否則按照原先的驗證方式進行驗證。
#coding=utf-8
importrandom
#生成0到10之間的随機數#d = random.uniform(0,10)#print d#生成一個1000到9999之間的随機整數
d = random.randint(1000,9999)
printu"生成的随機數:%d"%d i = input(u"請輸入随機數:")
printiifi == d:printu"登入成功!!"
elifi == 1111:printu"登入成功!!"
else:printu"請重新輸入驗證碼!"
運作結果:
>>> ================================ restart ================================ >>> 生成的随機數:3764 請輸入随機數:1111 1111 登入成功!! >>> ================================ restart ================================ >>> 生成的随機數:3763 請輸入随機數:3763 3763 登入成功!! >>> ================================ restart ================================ >>> 生成的随機數:1928 請輸入随機數:1354646 1354646 請重新輸入驗證碼!
random用于生成随機數
randint()方法用于生成随機整數,傳遞的兩個參數分别是随機數的範圍,randint(1000,9999)第二個參數要大于第一個參數。
我們要求使用者輸入随機數,并且對使用者輸入做判斷,如果等于生成的随機數那麼,登入成功,如果等于1111也算登入成功,否則失敗。那麼等于1111的判斷就是一個萬能碼。
驗證碼識别技術
記錄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 對象的名字。
最新内容請見作者的github頁:http://qaseven.github.io/