简述:
接口自动化主要的流程,就是接口请求,本次主要记录一下request请求的流程,以及请求的时候用到的第三方库requests,和请求的过程中用到的相关知识点。
**1、**接口鉴权,每个软件的不同,用到的鉴权方式自然也就不同了,主要有token。session。cookies。其中后面两个,requests库中的类:Session。在发送请求的时候会自动携带鉴权。
class HttpRequest:
"""
处理请求
"""
def __init__(self):
self.one_session = requests.Session()
除token鉴权外,这个就可以处理剩余的两种鉴权方式。
当然,本次我们主要讲解的是token鉴权,token鉴权分为两种形式,token在请求头header中,还有一种就是token在请求体中。由于本公司的token在请求体中,所以就不在叙述token在请求头中的相关代码。
def to_request(self, method, url, data=None, is_json=True, **kwargs):
method = method.upper()
if isinstance(data, str):
try:
data = json.loads(data)
except Exception as e:
# print("异常为: {}".format(e))
do_logger.error("将json转为Python中的数据类型时, 出现异常: {}".format(e))
data = eval(data)
if method == 'GET':
res = self.one_session.request(method=method, url=url, params=data, headers=headers, **kwargs)
elif method == 'POST':
if is_json: # 如果is_json为True, 那么以json格式来传参数
res = self.one_session.request(method=method, url=url, json=data, **kwargs)
else: # 否则, 以form表单来传参数
res = self.one_session.request(method=method, url=url, data=data, **kwargs)
else:
res = None
do_logger.error("不支持【{}】方法请求".format(method))
return res
**2、**请求数据格式主要有两种,application/x-www-form-urlencoded,上面的方法可以对这两种的请求格式进行处理,只需要将字典形式的字符串写入表格当中即可。首先导入json
dict_ss = {'mobile_phone': '186', 'pwd': '1234'}
# 将字典转换成json字符串
ss_json = json.dumps(dict_ss,ensure_ascii=False)
print(ss_json)
补充:将json格式的字符串转化为字典
ss = '{"mobile_phone":"1860","pwd":"12345"}'
# json字符串转换成字典
ss_dict = json.loads(ss)
print(ss_dict)
**3、**请求结束之后,记得关闭请求,及时释放资源
def close(self):
self.one_session.close()
**4、**最后一定要用main函数进行测试,看一下代码自己封装的类是否正确,我这里就不上代码了,自己可以找个登陆的接口试一下。
欢迎提问,大家一块进步呀。哈哈