前言
在讲解之前,我们首先要了解一下什么是接口测试?接口测试顾名思义就是对测试系统组件间接口的一种测试,接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。
python 接口测试入门
一、requests 库安装
pip install requests
二、http 请求类型
- get: 获取资源
- post :增加资源
- put: 修改资源
- delete: 删除资源
- head: 查看响应头
- options: 查看可用请求方法
三、Content-Type 编码方式
- application/x-www-form-urlencoded
默认地,表单数据会编码为 “application/x-www-form-urlencoded”。就是说,在发送到服务器之前,所有字符都会进行编码,空格转换为 “+” 加号,特殊符号转换为 ASCII HEX 值。 窗体数据被编码为:名称/值对,这是标准的编码格式。 - application/json
数据以 JSON 形式进行编码 - multipart/form-data
窗体数据被编码为一条消息,页上的每个控件对应消息中的一个部分,上传附件用到。在使用包含文件上传控件的表单时,必须使用该值。 - text/html
文本方式的网页文件。 - text/xml
文本方式的 XML 文件,text/xml 忽略 XML 头所指定编码格式而默认采用 US-ASCII 编码。 - text/plain
窗体数据以纯文本形式进行编码,其中不含任何控件或格式字符。空格转换为 “+” 加号,但不对特殊字符编码。 - application/xml
数据以 XML 形式进行编码,application/xml 会根据 XML 头指定的编码格式来编码。
四、get 请求
- 语法
requests.get(url, params=None, **kwargs) - 参数 url
调用接口地址
如:url=“http://httpbin.org/get” params
为可选参数,该参数是一个字典类型,数据会以键/值对的形式置于 URL 中,跟在一个问号的后面
如: https://api.github.com/events?key1=value1&key2=value2 **kwargs
其他可选参数
如 headers,files,cookies,auth,timeout,JSON 等 headers
请求头信息,与浏览器交互的参数 - 代码演示
import requests
import pprint
get_url='http://httpbin.org/get'
get_params={'key1':'value1','key2':'value2'}
res=requests.get(url=get_url,params=get_params)
pprint.pprint(res.json())
五、post 请求
- 语法
requests.post(url, data=None, json=None, **kwargs) - 参数
- url
调用接口地址
如:url=“http://httpbin.org/post” - data
为可选参数
如:字典、元组列表、字节或类似文件 - JSON
可选参数,JSON 数据 - **kwargs
其他可选参数
如 headers,files,cookies,auth,timeout,JSON 等 - headers
请求头信息,与浏览器交互的参数 - data 与 JSON 区别 传入 dict,不设置 content-type 值
data:默认使用 application/x-www-form-urlencoded 编码方式处理
JSON:默认使用 application/json 编码方式处理 传入 dict,设置 content-type 值
data&json 都按照设置的编码方式处理
- url
- 代码演示
import requests
import pprint
#data 接收,传入 dict,不设置 content-type 值
post_url='http://httpbin.org/post'
post_data={'key1':'value1','key2':'value2'}
res=requests.post(url=post_url,data=post_data)
pprint.pprint(res.json())import requests
import pprint
#json 接收,传入 dict,不设置 content-type 值
post_url='http://httpbin.org/post'
post_data={'key1':'value1','key2':'value2'}
res=requests.post(url=post_url,json=post_data)
pprint.pprint(res.json())import requests
import pprint
#data 接收,传入 dict,设置 content-type:application/json
post_url='http://httpbin.org/post'
post_data={'key1':'value1','key2':'value2'}
header={'Content-type':'application/json;charset=UTF-8'}
res=requests.post(url=post_url,data=post_data,headers=header)
pprint.pprint(res.json())import requests
import pprint
#json 接收,传入 dict,设置 content-type:application/x-www-form-urlencoded
post_url='http://httpbin.org/post'
post_data={'key1':'value1','key2':'value2'}
header={'Content-type':'application/x-www-form-urlencoded;charset=UTF-8'}
res=requests.post(url=post_url,json=post_data,headers=header)
pprint.pprint(res.json())
六、POST 与 GET 区别
- 参数传递
GET:从服务器获取数据,将数据按照 variable=value 的形式,添加到行为所指向的 URL 后面,并且两者使用“?”连接, 而各个变量之间使用“&”连接
POST:向服务器传送数据,将表单中的数据放在请求体中,按照变量和值相对应的方式传递。 - 长度限制
GET:GET 是通过 URL 提交数据,因此 GET 可提交的数据量就跟 URL 所能达到的最大长度有直接关系。
实际上 HTTP 协议对 URL 长度是没有限制的,限制 URL 长度大多数是浏览器或者服务器的配置参数。
POST:HTTP 协议没有对 POST 进行任何限制,一般是受服务器配置限制或者内存大小。
可以通过修改配置文件来设置。 - 安全性
GET:GET 请求参数放在 URL 后面,可以直接看到,明文传输。
POST:POST 请求参数放在请求体里面,需要通过抓包工具或者浏览器调试模式才能看到。 - 幂等性
幂等主要是为了处理同一个请求重复发送的情况。
比如在请求响应前失去连接,如果方法是幂等的,重复发送对结果没有影响。
通常情况下 GET 请求是幂等的,POST 请求非幂等的。
基本的接口测试入门就给大家介绍到这里了,感谢您的认真阅读,不二也会写出更优质的文章的,敬请期待哦!
写在最后
最后再唠唠一句,如果想以测试为长期发展职业目标,是需要时刻保持学习的,要使自己具备竞争力,无论你现在工作几年,只要行动起来,你就已经占优势了,好啦就到这里了,祝大家2022年能升职加薪,没入职的就早日拿到心仪公司的offer,事事顺遂。