python-接口自动化-接口请求

简述:
接口自动化主要的流程,就是接口请求,本次主要记录一下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函数进行测试,看一下代码自己封装的类是否正确,我这里就不上代码了,自己可以找个登陆的接口试一下。
欢迎提问,大家一块进步呀。哈哈

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值