所有加密,使用的数据都写在接口里 奥体整个后台也进行了重构,这套代码也使用不了了 现在的加密方式,完全看不懂 例: 这种加密没源码,想破脑袋也破解不了的
原文:所使用的模块:request和re 工具:pycharm和fiddler 微信小程序:苏州奥体
通过分析可得出订票总分为两步操作 1.选择场地 2.付款 所以只需要抓取到这两个接口就行 1.首先通过fiddler工具抓取到请求和参数 1.选择场地信息url信息url和请求参数 2.付款url信息url和请求参数 2.代码部分,编写脚本 选择场地代码 通过第一步操作,得到所需信息,使用request模块进行请求 // 选场地changdi_url = "https://sapb.szosc.cn/index.php/wxplace/place/pay"date = {'price': '30','fieldtype': '羽毛球场地','homename': '体育馆名称','field': '11:00-12:00|2021-09-07 11:00:00|6|30,12:00-13:00|2021-09-07 12:00:00|6|30','openid': '自己的id','unionid': '自己的id','limit': '1.0000','agree': '1'}response = requests.post(url=changdi_url, data=date) 下图为返回值信息 2.使用re模块,对返回值进行截取,从而得到下一个url所需的信息 //获取返回值信息response_text = response.text//通过正则匹配对应值outtradeno = re.findall('(name="outtradeno" value=")(.*)(" /)', response_text)[0][1]ordtotal_fee = re.findall('(name="ordtotal_fee" value=")(.*)(" /)', response_text)[0][1]homename = re.findall('(name="homename" value=")(.*)(" /)', response_text)[0][1]fieldtype = re.findall('(name="fieldtype" value=")(.*)(" /)', response_text)[0][1]fieldnum = re.findall('(name="fieldnum" value=")(.*)(" /)', response_text)[0][1]starttime = re.findall('(name="starttime" value=")(.*)(" /)', response_text)[0][1]bookinfo = re.findall('(name="bookinfo" value=")(.*)("/)', response_text)[0][1]uid = re.findall('(name="uid" value=")(.*)("/)', response_text)[0][1]paid = re.findall('(name="paid" value=")(.*)(" /)', response_text)[0][1]limit = re.findall('(name="limit" value=")(.*)("/)', response_text)[0][1]dttoken = re.findall('(name="dttoken" value=")(.*)("/)', response_text)[0][1]yhq = re.findall('(name="yhq" value=")(.*)("/)', response_text)[0][1]yhqid = re.findall('(name="yhqid" value=")(.*)("/)', response_text)[0][1]payType = re.findall('(name="payType" value=")(.*)(" /)', response_text)[0][1]vipCode = re.findall('(name="vipCode" value=")(.*)(" /)', response_text)[0][1]outTradeNo = re.findall('(name="outTradeNo" value=")(.*)(" /)', response_text)[0][1]totalFee = re.findall('(name="totalFee" value=")(.*)(" /)', response_text)[0][1]balanceMethod = re.findall('(name="balanceMethod" value=")(.*)(" /)', response_text)[0][1]cashAmount = re.findall('(name="cashAmount" value=")(.*)(" /)', response_text)[0][1] 其中有个值为sign,此值是通过加密所得,然后再传个下个接口 //加密方法def md5_encrypt(code):m = hashlib.md5()m.update(code.encode("utf-8"))sign = "123" + m.hexdigest()return sign //拼接原数据sign_old = "wxopenid" + outtradeno + bookinfo + paid + "Sport2021"//调用sign = md5_encrypt(sign_old) 付款部分 //将第一步返回数据,放到付款接口的参数里面pay_url = "https://sapb.szosc.cn/index.php/yinlian/index/pay"data = {'bookholder': '姓名','mobile': '电话',"idno": '','outtradeno': outtradeno,'ordtotal_fee': ordtotal_fee,'homename': homename,'fieldtype': fieldtype,'wxopenid': wxopenid,'unionid': unionid,'fieldnum': fieldnum,'starttime': starttime,'bookinfo': bookinfo,'uid': uid,'paid': paid,'limit': limit,'dttoken': dttoken,'yhq': yhq,'yhqid': yhqid,'sign': sign,'payType': payType,'vipCode': vipCode,'outTradeNo': outTradeNo,'totalFee': totalFee,'balanceMethod': balanceMethod,'cashAmount': cashAmount,'groupName': '','merchantCode': '','groupVipId': ''}resp = requests.post(url=pay_url, data=data) 关注微信公众号「躺平de咸鱼」 回复关键字「抢票」领取源码