Python接口自动化测试

接口测试流程:需求分析、用例设计、脚本编写、测试执行、结果分析
接口测试用例设计:Excel或XMind等思维导图软件编写,主要内容包括参数校验,功能校验,业务场景校验,安全性及性能校验等,
常用用例设计方法有等价类划分法,边界值分析法,场景分析法,因果图,正交表等

HTTP协议基础
HTTP:客户端-服务端
HTTPS:安全版http
reyquest四部分内容:
Request Method:请求方式——get和post
Request URL:请求链接——地址
Request Headers:请求头——用来说明服务器使用的附加信息:Cookie、Referer、User-Agent等

  Accept:请求报头域,用于指定客户端可接受哪些类型信息。

  Accept-language,指定客户端可接受的语言类型

  Accept-Encoding,指定客户端可接受的编码

  Host,用于指定请求资源的主机IP和端口号,其内容为请求URL的原始服务器或网管的位置

  Referer,此内容用来标识这个请求从哪个网页发过来的


Request Body:请求体post提交的数据类型

Response Headers    

Content-Type(

app;ocation/x-www-form-urlencoded   form 表单提交,

multipart/from-data    表单文件上传,

application/json    序列化Json数据提交,

text/XML   XML数据提交)


Response三部分:
Response Status Code:响应状态码例如:200成功 201已创建 401未授权 404未找到
Response Headers:服务器应答信息

  Date,标识Response 产生的时间

  Last-Modifed,指定资源的最后修改时间

  Content-Encoding,指定Response 内容和编码

  server,包含了服务器的信息,名称,版本号等

  Content-Type,文档类型,指定了返回的数据类型是什么,如text/html则返回HTML文档,application/x-javascript则返回javascript文件,image/jpeg则返回图片

  set-Cookie,设置Cookie,Response Headers中的Set-Cookie即告诉浏览器需要将此内容放在Cookies中,下次请求携带Cookies内容

  Expires,指定Response 的过期时间,使用它可以控制代理服务器或浏览器内容更新到缓存中,如果再次访问时,直接从缓存中加载,降低服务器负载,缩短加载时间

  

  User-Agent,简称UA,它是一个特殊字符串头,使得服务器能够识别客户端使用的操作系统及版本,浏览器及版本等信息,在做爬虫时加上此信息可以伪装为浏览器,如果不加很可能会被识别出爬虫
Response Body:响应体

HTTP协议的请求

  http请求由三部分组成,分别是:请求行、消息报头、请求正文。

请求方法(所有方法全为大写)有多种,各个方法的解释如下:

   GET:请求获取Request-URI所标识的资源;
   POST:在Request-URI所标识的资源后附加新的数据;
   HEAD:请求获取由Request-URI所标识的资源的响应消息报头;
   PUT:请求服务器存储一个资源,并用Request-URI作为其标识;
   DELETE:请求服务器删除Request-URI所标识的资源;
  TRACE:请求服务器回送收到的请求信息,主要用于测试或诊断;
  OPTIONS:请求查询服务器的性能,或者查询与资源相关的选项和需求应用;
  PATCH:实体中包含一个表,表中说明与该URI所表示的原内容的区别;
  MOVE:请求服务器将指定的页面移至另一个网络地址;
  COPY:请求服务器将指定的页面拷贝至另一个网络地址;
  LINK:请求服务器建立链接关系;
  UNLINK:断开链接关系;
  WRAPPED:允许客户端发送经过封装的请求;
  Extension-mothed:在不改动协议的前提下,可增加另外的方法。
 
HTTP协议的响应
  在接收和解释请求消息后,服务器返回一个HTTP响应消息,HTTP响应也是由三个部分组成,分别是: 状态行、消息报头、响应正文。
  a、状态行格式如下:HTTP-Version Status-Code Reason-Phrase CRLF其中,HTTP-Version表示服务器HTTP协议的版本;Status-Code表示服务器发回的响应状态代码;Reason-Phrase表示状态代码的文本描述。
  状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值:
  1xx:指示信息–表示请求已接收,继续处理;
  2xx:成功–表示请求已被成功接收、理解、接受;
  3xx:重定向–要完成请求必须进行更进一步的操作;
  4xx:客户端错误–请求有语法错误或请求无法实现;
  5xx:服务器端错误–服务器未能实现合法的请求;
  b、响应正文就是服务器返回的资源的内容。


Json:https://docs.python.org/3/library/json.html
数据在键/值对中    key:value   值:数字、字符串、逻辑值、数组、对象、null
数据由逗号分隔
{花括号}保存对象
[方括号]保存数组

json_dunmps:将python数据转化为Json数据
代码:
import json
data = {'id':1,'name':'51zxw','password':'666666'}
print(type(data))
json_str = json.dumps(data)
print(type(json_str))
print(json_str)
    
json_loads:将Json数据转化为python数据类型
代码:
import json
json_str = '{"id":1,"name":"51zxw","password":"666666"}'
print(type(json_str))
data = json.loads(json_str)
print(type(data))
print(data)
print(data['id'])
#文件类处理
with open("123","w") as f:
    json.dump(data,f)
with open('123','r') as f:
    a = json.load(f)
    print(a)

Request库的使用(基础)

#发送请求
r = requests.get('https://api.github.com/events')
# r = requests.post('http://httpbin.org/post', data = {'key':'value'})
# r = requests.put('http://httpbin.org/put', data = {'key':'value'})
# r = requests.delete('http://httpbin.org/delete')
# r = requests.head('http://httpbin.org/get')
# r = requests.options('http://httpbin.org/get')
# #传递URL参数
# payload = {'key1': 'value1', 'key2': 'value2'}
# r = requests.get("http://httpbin.org/get", params=payload)
#打印输出URL
print(r.url)

#响应内容
print(r.text)

#二进制响应内容
print(r.content)
#二进制数据创建图片
# from PIL import Image
# from io import BytesIO
# i = Image.open(BytesIO(r.content))
#JSON 响应内容
print(r.json())
#原始响应内容
print(r.raw)
#定制请求头
url = 'https://api.github.com/some/endpoint'
headers = {'user-agent': 'my-app/0.0.1'}
r = requests.get(url, headers=headers)
#更加复杂的 POST 请求
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.post("http://httpbin.org/post", data=payload)
print(r.text)
#POST一个多部分编码(Multipart-Encoded)的文件
url = 'http://httpbin.org/post'
files = {'file': open('report.xls', 'rb')}
r = requests.post(url, files=files)
r.text
#发送作为文件来接收字符串
url = 'http://httpbin.org/post'
files = {'file': ('report.csv', 'some,data,to,send\nanother,row,to,send\n')}
r = requests.post(url, files=files)
r.text
#响应状态码
r.status_code
#响应头
r.headers
#要想发送你的cookies到服务器,可以使用 cookies 参数
url = 'http://httpbin.org/cookies'
cookies = dict(cookies_are='working')
r = requests.get(url, cookies=cookies)
r.text

#禁用启用重定向
allow_redirects=False
allow_redirects=True

#超时
requests.get('http://github.com', timeout=0.001)

"""
错误与异常
遇到网络问题(如:DNS 查询失败、拒绝连接等)时,Requests 会抛出一个 ConnectionError 异常。
如果 HTTP 请求返回了不成功的状态码, Response.raise_for_status() 会抛出一个 HTTPError 异常。
若请求超时,则抛出一个 Timeout 异常。
若请求超过了设定的最大重定向次数,则会抛出一个 TooManyRedirects 异常。
所有Requests显式抛出的异常都继承自 requests.exceptions.RequestException 。
"""

POSTMAN授权设置
get postman-echo.com/basic-auth

basic-auth->Authorizetion->type:basic auth->用户名密码
get postman-echo.com/digest-aut
digest-auth->Authorizetion->type:digest-aut->用户名密码、Reaim、Nonce、Aigorithm

get postman-echo.com/auth/hawk
Hawk->Authorizetion->type:Hawk Authentication->
Hawk Auth ID、Hawk Auth Key、AlgorithmHawk Auth ID

get
postman-echo.com/oauth1
OAuth1.0->
Authorizetion->type:OAuth1.0->Consumer Key、Consumer SecretConsumer Key


->Authorizetion->type:digest-aut->

转载于:https://www.cnblogs.com/ssyyhh/p/9647889.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值