requests库的常用方法

之前都是用jmeter进行接口测试然后进行持续性集成,之前也写过用jmeter来请求各种类型的接口,今天来学习下如何使用python+requests对各种接口发起请求并断言。

1.接口类型

测试项目的ip和端口如下:

复制代码
host = "ip"
port = "8080"

1.1.get类型接口请求

复制代码
    def test_get_params(self):
        """
        请求方式为get
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/com/getSku"
        # 请求参数
        params = {"id": 1}
        #发起请求
        res = requests.get(url=url, params=params)
        print(res.text)
        assert res.status_code == 200

1.2.post类型接口请求,参数为params

复制代码
    def test_post_params(self):
        """
        请求方式为post,请求参数为params
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/com/login"
        # 请求参数
        params = {"userName": "admin", "password": "1234"}
        res = requests.post(url=url, params=params)
        print(res.text)
        assert res.status_code == 200

1.3.post类型接口请求,参数为json

复制代码
    def test_post_json(self):
        """
        请求方式为post,请求参数为json
        :return:
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/com/register"
        json = {"userName": "test", "password": "1234", "gender": 1, "phoneNum": "110", "email": "beihe@163.com",
                "address": "Beijing"}
        res = requests.post(url=url, json=json)
        print(res.text)
        assert res.status_code == 200

1.4.post类型接口请求,参数为k=json

复制代码
    def test_post_params_json(self):
        """
        请求方式为post,请求参数为k=json
        :return:
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/com/buy"
        params = {"param": '{"skuId":123,"num":10}'}
        res = requests.post(url=url, params=params)
        print(res.text)
        assert res.status_code == 200

2.上传

复制代码
    def test_upload(self):
        url = "http://" + self.host + ":" + self.port + "/pinter/file/api/upload"
        files={
            'file':open(file=r'C:\Users\29442\Desktop\user.txt',mode='rb')
        }
        #发起接口调佣
        res=requests.post(url=url,files=files)
        print(res.text)

3.获取token

部分接口依赖登录接口中的token,可以将登录接口中的token提取出来,用global定义为全局变量,然后在其它接口的header中进行调用,如下图所示。

复制代码
    def test_login_token(self):
        """
        测试登录,带token
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/bank/api/login2"
        params = {"userName":"admin","password":"1234"}
        res = requests.post(url=url, params=params)
        text=json.loads(res.text)
        print(text)
        global token
        token=text.get("data")

        assert res.status_code == 200

    def test_token(self):
        """
        查询余额,带token
        """
        headers={
            "testfan-token":token
        }

        url = "http://" + self.host + ":" + self.port + "/pinter/bank/api/query2"
        params = {"userName":"admin"}
        res = requests.get(url=url, params=params,headers=headers)
        print(res.text)
        assert res.status_code == 200

4.自动获取cookie

部分接口依赖登录接口的cookie,在代码中如果我们使用固定的cookie,cookie失效之后又需要人为手动填充很不方便,requests给我们提供了一种方法可以自动获取cookie,可以用session获取到cookie之后再用session调用方法发起请求,如下图所示。

复制代码
    #通过session自动获取cookie
    session = requests.session()
    def test_login_cookie(self):
        """
        测试登录,带Cookie
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/bank/api/login"
        params = {"userName":"admin","password":"1234"}
        res = self.session.post(url=url, params=params)
        print(res.text)

        assert res.status_code == 200

    def test_cookie(self):
        """
        查询余额,带Cookie
        """
        url = "http://" + self.host + ":" + self.port + "/pinter/bank/api/query"
        params = {"userName":"admin"}
        res = self.session.get(url=url, params=params)
        print(res.text)
        assert res.status_code == 200
相关推荐
程序媛kelly7 分钟前
如何打开 .md / .ipynb 文件?Markdown 与 Jupyter Notebook 本地预览全攻略
ide·python·jupyter
KaMeidebaby12 分钟前
卡梅德生物技术快报 | Fab 合成文库构建与抗体筛选实验流程及数据解析
人工智能·python·tcp/ip·算法·机器学习
装不满的克莱因瓶14 分钟前
掌握3D CNN模型结构——从时空特征建模到视频理解与医学影像核心架构
人工智能·pytorch·python·深度学习·神经网络·3d·cnn
AINative软件工程15 分钟前
LLM 应用的 Schema 演进工程:structured output 字段改了,下游为什么炸了?
后端·python·架构
法海爱捉虫27 分钟前
小微企业 / 货代专用快递打单工具,适配热敏 / A4 打印机 功能设计
python
asdzx6733 分钟前
Python 优雅解析 Excel:从原生行列到强类型对象的三层数据结构演进
数据结构·python·excel
码云骑士40 分钟前
26-密码密钥配置管理-env文件与多环境隔离策略
python
装不满的克莱因瓶41 分钟前
掌握基于YOLO v5实现车牌目标检测任务的完整流程——从数据到部署的工业级实践
人工智能·python·深度学习·yolo·目标检测·计算机视觉·目标跟踪
骑士雄师42 分钟前
1.1 rag开发基础配置
python