最近做一个登录接口测试中,发现了以下的一些场景,本次将所遇到的问题以及解决过程做下记录:
1、抓包发现登录操作时,先后请求三个接口,并且每个接口有关联
2、每次请求都需要保留cookie信息,下个接口请求需要
3、每个接口返回数据非json格式,提取数据需要另外操作
本篇文档就从这三点来开始讲
1、首先看抓包情况与大致框架分析
先后请求3条接口,然后我们一条一条来分析
①整体来看,都是get请求,且共同参数都是service、callback、_,第2条和第3条都还有其他的参数
②第1条接口返回的数据中data下的两个字段就是第2个接口的参数
③第2条接口返回数据中的某个字段是第3条接口的参数
综合以上就写大致的框架
#coding:utf-8
import requests,re
url = "xxxxx"
#tt就代替那个_作为参数了
def login1(service,callback,tt):
pass
#三条接口相互依赖,第2个接口参数来源第1个接口返回值
def login2():
pass
#三条接口相互依赖,第3个接口参数来源第2个接口返回值
def login3():
pass
if __name__ == '__main__':
service = 'xxxxxx'
callback = 'xxxxxxx'
tt = 'xxxxxxx'
login3(service, callback, tt)
2、然后就是正常的编写get请求了
这里的返回值因为不是json格式,就不用json.loads() 这么写了,先打印查看
3、上面已经说到,这里的lt和execution 都是下个接口的参数,所以此刻需要将他们的值提取出来
这就涉及到正则提取了
ps:推荐个调试的网站 http://tools.jb51.net/regex/javascript
python正则表达学习地址:https://www.jb51.net/article/177521.htm
python中这里写起来也简单,具体见下面脚本中的备注信息
def login1(service,callback,tt):
print("开始执行login1")
url = url1 + "/sso/login"
params = {
"service":service,
"callback":callback,
"_":tt
}
req = requests.get(url = url,params=params)
print(req.text)
#返回结果转换为字符串
response_str = str(req.text)
#正则提取字符串信息,返回列表,提取data下的信息
m = re.findall(r'{.*?}',response_str)[0]
#data下就是key-value形式,通过eval()将字符串转换为字典,然后字典中通过key提取到value值
lt = eval(m)['lt']
execution = eval(m)['execution']
return lt,execution
4、第2个接口编写,并将第1个接口返回的东西带入
def login2(service,callback,tt):
lt,execution = login1(service,callback,tt)
print("开始执行login2")
执行过程中发现报302错误
302错误:redirect,代表暂时性转移;意思就是你访问网址a,但是因为服务端的拦截器或者其他代码处理,会被重定向到网址b。
利用requests模拟登录时,直接使用request.get(url),容易造成 302 重定向,究其原因是因为cookie不持久(requests自带cookie处理,但不持久)
所以这里 我们就需要将cookie存储下来并使用起来
具体cookie用法见路径:https://www.cnblogs.com/liuzhzhao/p/12114453.html
5、知道怎么使用了,那么我们代码修改一下
后面的脚本就照葫芦画瓢了,第1个接口的cookie信息保存给到第2个接口使用,第2个接口的cookie保存,给到第3个接口使用
整体上就写完了,后面需要单独补充下就好
本次主要知识点:接口依赖调用、cookie保存与使用、python关键信息正则提取