原先呢我没想着要搞这个,我自己感觉点点点还是比较舒服的。但是极地冰川消融导致海平面上升,让我突然觉得这是有必要的。
扯皮的话不多说,我们需要先把思路理理清楚,这个时候倒立起来总会有其他意想不到的效果。
发了一个正常的请求,看到我购买成功后返回结果是:"state"=1。知道这个结果以后,根据自己的业务经验可以总结出,需要以下几个步骤来完成。
所有的逻辑都是在正常登陆的情况下产生的,so,登陆的方法不能少:
return的是登陆后产生的一个auth值,之后的操作会用到这个值。
这个是直接用缓存页面获取的,也可以正常登陆获取,
获取的方法可以用正则,也可以直接转换取值,效果都是一样的。
1 # coding:utf-8 2 import requests 3 import re 4 def Login(s): 5 ''' 6 保持uid 314948的登陆状态 7 :return:提取auth的值 8 ''' 9 url = 'http://crmtest.bdwork.com/member.php?mod=logging&action=login&referer=' 10 h = { 11 'Host': 'crmtest.bdwork.com', 12 'Connection': 'keep-alive', 13 'Upgrade-Insecure-Requests': '1', 14 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 UBrowser/6.2.4092.1 Safari/537.36', 15 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', 16 'Referer': 'http://crmtest.bdwork.com/home.php?mod=spacecp&ac=look', 17 'Accept-Encoding': 'gzip, deflate', 18 'Accept-Language': 'zh-CN,zh;q=0.8' 19 } 20 cookie = { 21 'brandclick':'brandclick', 22 'KY1F_c7af_saltkey':'c32x3x6a', 23 'KY1F_c7af_lastvisit':'1533198615', 24 'KY1F_c7af_sendmail':'1', 25 'KY1F_c7af_noticeTitle':'1', 26 'UM_distinctid':'164f9f95c5830e-0679413bf11568-4c531929-100200-164f9f95c59474', 27 'KY1F_c7af__refer':'%252Fhome.php%253Fmod%253Dspacecp%2526ac%253Dlook', 28 'CNZZDATA1259972829':'1337227657-1530510545-%7C1533198970', 29 'Hm_lvt_aabf378828361ace85e070bda547e0c2':'1532587790,1532703535,1532934413,1533188504', 30 'Hm_lpvt_aabf378828361ace85e070bda547e0c2':'1533202228', 31 'Hm_lvt_855f1a9b2df256430c5190b4c155e0be':'1532587790,1532703535,1532934413,1533188504', 32 'Hm_lpvt_855f1a9b2df256430c5190b4c155e0be':'1533202229', 33 'KY1F_c7af_lastact':'1533202227%09member.php%09logging', 34 'encodemobile':'cP22pue9GTQnWMxgrOUowqIFOw', 35 'name':'17621212121', 36 'KY1F_c7af_ulastactivity':'e4df0yITlF8mbtqQE5dAg%2FzDeXDv%2B3mOev0miMuxK8fR%2FG2WwF%2Fc', 37 'KY1F_c7af_sid':'m3ApNB', 38 'KY1F_c7af_auth':'b61asNdM0xvEJX17xo6x8LhP3d7utK0DAWkXCm23DiIx262XHLcqgzsh4Qdm7jOjCwsiIOGy0LJFiYiTlfwI%2BcQqpng', 39 'KY1F_c7af_lastcheckfeed':'314948%7C1533202227', 40 'KY1F_c7af_checkfollow':'1', 41 'KY1F_c7af_lip':'116.226.114.196%2C1533201831', 42 'KY1F_c7af_security_cookiereport':'921azQNj36RYks%2BTjCXtqUSWvv9kMJQOPGbKe4zawKNQngh3mPI8' 43 } 44 d = s.get(url,headers=h,cookies=cookie) 45 r = d.text 46 # if '吕振华' in r: 47 # print('登陆成功,提取auth:',) 48 # else: 49 # print('登录失败') 50 auth0 = re.findall(r"auth = \"(.+?)\";",r) 51 auth = ''.join(auth0) 52 return auth 53 if __name__ in '__main__': 54 s = requests.session() 55 # print('\'',''.join(Login(s)),'\'') 56 print(Login(s))
登陆之后要做什么呢,当然是操作购买道具,会员等等需要支付的动作:
例如,道具刷新卡
1 # coding:utf-8 2 import requests 3 4 s = requests.session() 5 def test_g_1(auth): 6 ''' 7 刷新卡购买 8 :return:state=1正确 9 ''' 10 url = 'http://crmtest.bdwork.com/appapi.php?mod=pay_transeMoney' 11 h = { 12 'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.146 Safari/537.36', 13 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', 14 'Referer': 'http://crmtest.bdwork.com/member.php?mod=txl&act=zhifu&zhifu_type=4&authorid=1&bump_id=1&id=33&idtype=tid&tid=&url=', 15 'Accept-Encoding': 'gzip, deflate', 16 'Accept-Language': 'zh-CN,zh;q=0.9', 17 'Cookie': 'name=17621212121', 18 'Host': 'crmtest.bdwork.com', 19 'Content-Length': '88' 20 } 21 22 body = { 23 'uid':'314948', 24 'auth':auth, 25 'tuid':'1', 26 'amount':'1', 27 'transtype':'-22', 28 'applyid':'1' 29 } 30 r = s.post(url,data=body,headers=h) 31 return r.text 32 # if __name__ in '__main__': 33 # try: 34 # auth = login.Login(s) 35 # print(test_g_1(auth)) 36 # except: 37 # pass
购买完成之后,系统里就没有什么操作了,接下来只需要在unittest中写好用例就ok了。
开始之前需要打开session,接着添加备注提示,然后调用login方法提取操作必须的auth值,之后调用购买道具方法并打印出提示信息,最后添加断言就完工啦。
1 import unittest 2 import requests 3 class TestCase(unittest.TestCase): 4 #开始前打开session 5 @classmethod 6 def setUpClass(cls): 7 cls.s = requests.session() 8 9 def test_Shauxinka(self): 10 ''' 11 刷新卡购买 12 :return: 当state=1时通过 13 ''' 14 #调用登陆方法,提取auth值 15 auth = login.Login(self.s) 16 q = shuaxinka.test_g_1(auth) 17 print('刷新卡购买返回状态为:%s'%q) 18 #添加断言 19 self.assertTrue(q == '{"state":1}')
单个道具写完就可以花时间把所有相关的动作总结一下,ctrl+c,ctrl+v
需要生成报告的可以自行百度一下,我贴个效果图出来:
到这里就算整体完成了,总结一下,
首先梳理思路,然后做出相应的操作,最后添加unittest用例
言辞略显简陋,如有雷同,不胜荣幸。