通过服务器获取验证码

测试自动化在遇见有验证码的情况时通常的做法是:

1. 去掉验证码

2. 设置万能验证码

3. 验证码识别技术

4. 记录cookie

 

以上方法各有优缺点,这里不再赘述,只简单介绍一种不用任何改动简单有效不影响流程的方法,直接上源码:

 

# -*- coding:utf-8 -*-
# Python27 import paramiko,datetime import selenium.webdriver as webdriver # 连接服务器获取验证码 def getpin(sessionid): hostname = '111.111.111.111' port = 8989 username = 'testname' key_file = 'D:\Butterfly\sandbox' date = datetime.datetime.now().strftime('%Y-%m-%d') key = paramiko.RSAKey.from_private_key_file(key_file) sessionid = sessionid s = paramiko.SSHClient() s.load_system_host_keys() s.set_missing_host_key_policy(paramiko.AutoAddPolicy()) s.connect(hostname,port,username,pkey=key,timeout=5) cmd = "tac /opt/tomcat/logs/catalina." + date + ".out | grep " + sessionid + ":validateCode | sed -n '1p'" print cmd stdin,stdout,stderr = s.exec_command(cmd) cmd_result = stdout.read(),stderr.read() print cmd_result for line in cmd_result: if line : pincode = line[-5:-1] s.close() return pincode # 打开浏览器获取session driver = webdriver.Chrome() driver.get('https://new.xxx.com/') cookies = driver.get_cookies() for cookie in cookies: print "%s -> %s" % (cookie['name'], cookie['value']) if cookie['name'] == 'JSESSIONID': sessionid = cookie['value'] if sessionid: print "sessionid is :" + sessionid pincode = getpin(sessionid) else: print "获取session失败" # 页面信息填写 driver.find_element_by_id("mobile").send_keys("18122223333") driver.find_element_by_id("password").send_keys("11111111") driver.find_element_by_id("validateCode").send_keys(pincode)

 

运行结果为:

_check_code_loginregister -> 1460449532856
JSESSIONID -> 11A50AF9CF61E4EA541B4AE6BE516D20-n1
Hm_lvt_04da9d36c446fb5cac2ee84477faa8e8 -> 1460449432
Hm_lpvt_04da9d36c446fb5cac2ee84477faa8e8 -> 1460449432
sessionid is :11A50AF9CF61E4EA541B4AE6BE516D20-n1
tac /opt/tomcat/logs/catalina.2016-04-12.out | grep 11A50AF9CF61E4EA541B4AE6BE516D20-n1:validateCode | sed -n '1p'
('2016-04-12 16:25:33,351 [http-bio-8080-exec-2] INFO  com.gamaxpay.website.util.VerifyCodeServlet - 11A50AF9CF61E4EA541B4AE6BE516D20-n1:validateCode:https://new.mo9.com/verifyCodeServlet:5TBV\n', '')

 代码比较简单,不再赘述。原理简单说就是:将sessionid和验证码记录在日志文件中,调起浏览器后根据sessionid去浏览器中取出验证码即可

 

转载于:https://www.cnblogs.com/Hebe/p/5383330.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值