在做接口测试时,在python中内置了HTTP库 urllib,可以用于发送http请求。基于urllib二次封装的三方库Requests,相较于urllib更佳简介易用。所以,在接口自动化测试中通常使用Requests库对接口进行测试
因为Requests是第三方库,所以需要对其进行安装,通常安装使用pip命令安装即可
- # 在终端命令行或python编辑工具pycharm的Terminal中输入以下指令即可
- pip install requests


安装完成后,在编辑器中引入对应的库import requests
HTTP接口测试涉及到3个方面
请求方法:get、post、put、 delete、head ......
请求体:form、json、xml、 binary
响应结果:status code、 response body、 json path、 xpath
接口常见的请求方法及类型如下
- #【如有问题,关注公众号:程序员山茶】留言
-
- r = requests.get('http://127.0.0.1:8080/shancha/test_one') #get请求
- r = requests.post('http://127.0.0.1:8080/shancha/test_one', data = {'key':'value'})#post请求
- r = requests.put('http://127.0.0.1:8080/shancha/test_one', data = {'key':'value'})
- r = requests.delete('http://127.0.0.1:8080/shancha/test_one')
- r = requests.head('http://127.0.0.1:8080/shancha/test_one')
- r = requests.options('http://127.0.0.1:8080/shancha/test_one')
-
-
- #【如有问题,关注公众号:程序员山茶】留言
- # 构造请求目标
- import resquests
- r = requests.get('http://127.0.0.1:8080/shancha/test_one')
- print(r.status_code) # 响应结果为 200
-
- # 构造请求头
- url = 'http://127.0.0.1:8080/shancha/test_one'
- headers ={'user-agent': 'my-app/0.0.1'}
- r = requests.get(url, headers=headers)
- print(r.status_code) # 响应结果为 200
-
- # 构造请求cookie
- url = 'http://127.0.0.1:8080/shancha/test_one'
- cookies = dict(cookies_are='chengxuyuanshancha')
- r = requests.get(url, cookies=cookies)
- print(r.status_code) # 响应结果为 200
请求体key:value 即键值对的形式存在,如query参数、form请求、binary请求(上传文件)以及json、xml、 json rpc等结构化请求
- # form 和 Json 示例如下
- #【如有问题,关注公众号:程序员山茶】留言
-
- # form请求
- payload = {'key':'valuel','key2':'value2'}
- r = requests.post("http://127.0.0.1:8080/shancha/test_one", data=payload)
- print(r.status_code) # 响应结果为 200
-
- # JSON请求
- url = 'http://127.0.0.1:8080/shancha/test_one'
- payload = {'some': 'data'}
- r = requests.post(url, json=payload)
- print(r.status_code) # 响应结果为 200
在做测试时,结果判断是功能实现的重要依据之一。结果判断也可以称之为响应断言,即对请求动作结果返回的预期
响应的类型有多种
r.url:
r.status_code
r.headers
r.cookies
r.encoding
r.content
r.text
r.json()
以接口API为例
- #【如有问题,关注公众号:程序员山茶】留言
-
- # 结构化响应断言方式
- import requests
- import json
-
- r = requests.get('https://api.github.com/repos/hiyongz/DjangoDemo')
- json_data = r.json()
- print(json.dumps(json_data, indent=4))
- # 返回信息结果为
- {
- "message": "API rate limit exceeded for 50.7.252.58. (But here's the good news: Authenticated requests get a higher rate limit. Check out the documentation for more details.)",
- "documentation_url": "https://docs.github.com/rest/overview/resources-in-the-rest-api#rate-limiting"
- }
除了常用的Assert断言以外, 还有Hamcrest 断言、xml解析断言、schema断言、JSONPath断言等多种断言方式,断言也可以组合使用,在测试过程中要根据返回的结果数据选择适合的断言方法
使用Springboot编写一个接口“/shancha/test_one”,且在web端也可以访问
-
- @RestController
- @RequestMapping("/shancha")
- public class FirstController {
-
- @Autowired
- FirstService firstService;
-
- @GetMapping("/test_one")
- public String showNlefer(){
- System.out.println("我是山茶,公众号:程序员山茶。有问题请公众号留言!");
-
- return "{\"name\":\"山茶\",\"公众号\":\"程序员山茶\"}";
- }
-
-
- }
web端访问结果

使用requests测试接口
- import requests
-
- def requestsShanCha():
- r = requests.get('http://127.0.0.1:8080/shancha/test_one')
- assert r.status_code == 200
- print(r.status_code)
- print(r.headers)
- print(r.content)
- print("返回信息结果:"+r.text)
-
-
-
- if __name__ == '__main__':
- requestsShanCha()
响应结果如下所示,与web浏览器响应结果一致

以上,本文完,如果你觉着有用就点个“赞呗👍”
作者简介:
程序员山茶,一个工作5年,并坚持探索测试之路的测试开发工程师。曾混迹于互联网大厂、IOTA行业领航企业、安全行业、大数据行业领航企业,欢迎和我一起沟通交流。

欢迎关注我, 和我一起探索AI+测试之路,终身成长