接口测试基础学习

接口测试基础学习接口测试快速上手资料

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

接口测试基础学习

(一)http协议基础
协议基础
请求消息
响应消息
(二)接口测试概述
(三)Requests库介绍
(四)抓包工具 fiddler
(五)URL参数
(六)响应消息
(七)Session机制
(八)待更新
问题记录

(一)http协议基础
协议基础
  1. HTTP 协议最大的特点是 通讯双方 分为 客户端服务端 。由于 目前 HTTP是基于 TCP 协议的, 所以要进行通讯,客户端 必须先 和服务端 创建 TCP 连接。
  2. 而且 HTTP 双方的信息交互,必须是这样一种方式:客户端 先发送 http请求(request)给 服务端,然后服务端 发送 http响应(response)给 客户端
  3. 特别注意:HTTP协议中,服务端不能主动先发送信息给 客户端
请求消息报文格式:

请求行 request line

GET /mgr/login.html HTTP/1.1
表示要 获取 资源, 资源的 地址 是 /mgr/login.html , 使用的 协议 是 HTTP/1.1

请求头 request headers

Host: www.baiyueheiyu.com
User-Agent: Mozilla/6.0 (compatible; MSIE5.01; Windows NT)
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
通常请求头 都有好多个,一个请求头 占据一行单个请求头的
格式是: 名字: 值

请求消息体 message body 用于存放数据信息,例如上传和修改信息

如果 HTTP 请求 有 消息体, 协议规定 需要在 消息头和消息体 之间 插入一个空行, 隔开 它们。
请求消息体中保存了要提交给服务端的数据信息。
消息体的格式
WEB API 请求消息体 通常是某种格式的文本,常见的有
Json
Xml
www-form-urlencoded

响应消息报文格式:

HTTP/1.1 200 OK
Date: Thu, 19 Sep 2019 08:08:27 GMT
Server: WSGIServer/0.2 CPython/3.7.3
Content-Type: application/json
Content-Length: 37
X-Frame-Options: SAMEORIGIN
Vary: Cookie

{“ret”: 0, “retlist”: [], “total”: 0}
状态行
HTTP/1.1 200 OK 里面有5种状态,此处略去

响应头

响应头 是 响应状态行下面的 的内容,里面存放 一些 信息

响应消息体
同请求的消息体

请求消息体一样,WEB API 响应消息体 通常也是某种格式的文本,
常见的有:
Json
Xml
www-form-urlencoded

(二)接口测试概述

接口测试(或者API接口测试),其实就是 对 软件系统 消息交互接口 的测试
消息交互接口软件系统其他软件系统 交互 的那部分。

接口测试就是

  1. 依据接口规范,写出测试用例
  2. 使用软件工具(postman,JMeter),直接通过消息接口 对 被测系统 进行消息收发
  3. 验证被测系统行为是否正确。
(三)Requests库介绍

Requests 库 是用来发送HTTP请求,接收HTTP响应的一个Python库

requests库的中文文档:https://cn.python-requests.org/zh_CN/latest/

Requests可以很方便的发送HTTP请求给服务器。比如

import requests
response = requests.get(‘http://mirrors.sohu.com/’)
print(response.text)

(四)抓包工具 fiddler

待更新

(五)构建http请求

URL参数
https://www.baidu.com/s?wd=iphone&rsv_spt=1
问号后面的部分 wd=iphone&rsv_spt=1 就是 url 参数,每个参数之间是用 & 隔开的。
上面的例子中 有两个参数 wd 和 rsv_spt, 他们的值分别为 iphone 和 1 。
url参数的格式,有个术语叫 urlencoded 格式。

构建请求头

指定参数 headers 的值为这个字典就可以了,如下headers = {

‘user-agent’: ‘my-app/0.0.1’,
‘auth-type’: ‘jwt-token’
}

r = requests.post(“http://httpbin.org/post”, headers=headers)
print(r.text)

构建消息体

当我们进行API 接口测试的时候, 根据接口规范,构建的http请求,通常需要构建消息体。
http 的 消息体就是一串字节,里面包含了一些信息。这些信息可能是文本,比如html网页作为消息体,也可能是视频、音频等信息。

Web API接口中,消息体基本都是文本,
文本的格式主要是这3种: urlencoded ,json , XML。
如下分别举例子进行解释:

第一种:xml的格式的消息体
如果设计者决定用 XML 格式传输一段信息,用Requests库,只需要这样payload = ‘’’

<?xml version=”1.0″ encoding=”UTF-8″?> 良好 30% 暂无 ”’ r = requests.post(“http://httpbin.org/post”, data=payload.encode(‘utf8’)) print(r.text)

第二种:urlencoded 格式消息体

payload = {‘key1’: ‘value1’, ‘key2’: ‘value2’}
r = requests.post(“http://httpbin.org/post”, data=payload) print(r.text)
第三种:JSON格式(两种格式)
r = requests.post(“http://httpbin.org/post”, data=json.dumps(payload)) 或者

r = requests.post(“http://httpbin.org/post”, json=payload) 推荐这种形式

json.dumps() # 进行编码,序列化的操作 Python对象—>字符串 用于在网络中传输
json.loads() # 进行解码,反序列的操作 字符串—>Python对象 用于在代码中操作

(六)响应消息

处理响应消息的2种通用的方法:
第一种:
r = requests.get(“http://www.python3.vip/”)
print(r.content) #获得原始的字节串 print(r.content.decode(“utf-8”)) # 在进行对字符串的解码操作,得到正确的格式
第二种:
r = requests.get(“http://www.python3.vip/”)
r.encoding =“utf-8” # 指定格式,获得文本
print(r.text)
print(r.encoding)

JOSN的响应的消息
使用的前提:知道返回的是JOSN格式的
r = requests.post(
“http://httpbin.org/post”,
data={“A”:1,“B”:2}
)
print(json.loads(r.content.decode(“utf-8”)))
以上得到的结果就是JSON格式的
举例子如下:
r = json.loads(r.content.decode(“utf-8”))
print(r.get(“headers”).get(“Host”)) #得到里面的关键信心
好处:将数据转换成josn方便的快速的处理
以上为原理的分析,以下为推荐使用的方法:
r = r.json()
print(r.get(“headers”).get(“Host”))

(七)Session机制

含义:会话的意识
原理分析:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Em3S8AHw-1643553641478)(en-resource://database/1446:1)]

从上图可以看出, 服务端是通过 HTTP的响应头 Set-Cookie 把产生的 sessionid 告诉客户端的。
客户端的后续请求,是通过 HTTP的请求头 Cookie 告诉服务端它所持有的sessionid的。
cookie 英文就是小甜饼的意思,这里表示一小段数据。

requests处理session-cookie

requests库给我们提供一个 Session 类。
通过这个类,无需我们操心, requests库自动帮我们保存服务端返回的 cookie数据, HTTP请求自动 在消息头中放入 cookie 数据

用法如下:

session = requests.Session()

创建 Session 对象 s = requests.Session() # 通过 Session 对象 发送请求 r
esponse = s.post(“http://127.0.0.1/api/mgr/signin”, data={ ‘username’: ‘byhy’, ‘password’: ‘88888888’ }) printResponse(response)

(八)
问题记录
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/168443.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 线性反馈移位寄存器的实现原理_线性移位寄存器序列

    线性反馈移位寄存器的实现原理_线性移位寄存器序列1、写出n阶线性反馈移位寄存器的实现过程2、假设一个GF(2)上的5阶线性反馈移位寄存器的反馈函数为f(x1,x2,x3,x4,x5)=x1+x5初始状态为10011,试写出该线性反馈移位寄存器的输出序列程序:#include#includeusingnamespacestd;voidGF(inta,intn){intb;

  • c++ string头文件详解[通俗易懂]

    标准c++中string类函数介绍注意不是CString之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必担心内存是否足够、字符串长度等等,而且作为一个类出现,他集成的操作函数足以完成我们大多数情况下(甚至是100%)的需要。我们可以用=进行赋值操作,==进行比较,+做串联(是不是很简单?)。我们尽可以把它看成是C++的基本数据类型。…

  • WebStorm快捷键以及个人设置[通俗易懂]

    WebStorm快捷键以及个人设置[通俗易懂]WebStorm是JetBrains推出的一款商业的JavaScript开发工具任何一个编辑器都需要保存(ctrl+s),这是所有win平台上编辑类软件的特点,但是webstorm编辑文件右上角是没有那个熟悉的*的。好处:省去了ctrl+s之后,在结合Firefox的vim,基本不动鼠标就可以看到结果页面了。坏处:没有以前的*标识,万一键盘误操作也会被立即存储。任…

  • PID控制学习–原理(一)

    PID控制学习–原理(一)目录一、PID控制原理与程序流程1、过程控制2、PID调节各个单元的作用二、数字PID控制器1、模拟PID控制规律的离散化2、数字PID控制器的差分方程3、常见的控制方式4、PID算法的两种形式三、PID算法的程序流程1、增量型PID算法的程序流程2、位置型PID控制的程序流程3、程序流程四、标准PID算法的改进1、微分项的改进2、微分线…

  • HTML实体对照表

    HTML实体对照表

    2021年10月20日
  • linux下查看memcache是否正常

    linux下查看memcache是否正常

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号