全网最细,python自动化测试requests库深度详解,精通实战......


前言

发送HTTP请求

import requests


# 登录的接口地址
url = 'http://............/login'
# 登录的参数
params = {
    
    
    "mobile_phone": 18300000000,
    "pwd": 12345678
}
# 请求头
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
# 发送登录请求
# 请求类型为 Content-Type:Application/json,参数就应该使用json去传递
response = requests.post(url=url, json=params, headers=headers)
print(response)    # 响应对象
print(response.text)   # 获取接口返回的数据

requests处理常见的接口请求参数类型(重要)

1、查询字符串参数:
常用于get请求(其他的请求方法用的少)
参数会直接拼接在url地址后面
requests发送请求,传递查询字符串参数,要使用params

Python接口自动化测试:https://www.bilibili.com/video/BV16G411x76E/

import requests


url = 'http://............/'
# 请求参数
params = {
    
    
    'pageIndex': 1,
    'pageSize': 20
}
# 请求头
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
response = requests.get(url=url, params=params, headers=headers)
print(response.text)

2、json类型的参数:
请求类型为 Content-Type:Application/json
requests发送请求,传递json参数,就应该使用json去传递

import requests


url = 'http://............/member/register'
# 请求参数
params = {
    
    
   "mobile_phone":183000000000,
   "pwd":12345678
}
# 请求头
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
response = requests.post(url=url, json=params, headers=headers)
print(response.text)

3、表单类型的参数:
请求参数类型:content-type: application/x-www-form-urlencoded*
requests发送请求,传递表单参数,应该使用data去传递

import requests


# 登录接口
url = 'https://............../UserApi/login'
# 请求参数
params = {
    
    
   "email":183000000000,
   "password":12345678,
    'remember':0
}
# 请求头
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
response = requests.post(url=url, data=params)
print(response.json())

4、文件上传
请求参数类型:content-type:application/form-data(postman请求参数也选择这个)
文件参数要使用files进行传递
文件参数的组装:两种形式****
{“参数名”:(“文件名”,open以rb模式打开文件,“文件类型”)}
{(“参数名”,(“文件名”,open以rb模式打开文件,“文件类型”))}

import requests


# 本地的上传文件接口地址
url = 'http://127.0.0.1:5000/upload'
# 请求参数
params = {
    
    
   "nickname":'1122',
   "age":18,
    'sex':'男'
}
file = {
    
    
    'pic':('jiayouya.gif',open('jiayouya.gif','rb'),'image/gif')
}
response = requests.post(url=url, data=params, files = file)
print(response.json())

返回的数据提取

text属性(str):获取的是原生的json字符串(有可能出现乱码)

请添加图片描述

content属性(bytes):可以使用decode指定编码转换为字符串(可以解决乱码问题)

请添加图片描述

json()方法(dict):获取到的是json转换的字典/列表(自动转换成python数据,使用起来更方便)

请添加图片描述

json类型数据和python数据的对比

json python
{}: 对象 字典
[]: 数组 列表
空: null None
布尔值: falsetrue FalseTrue

jsonpath提取数据和json数据

安装:pip install jsonpath
通过字典键值对的方式获取token

import requests


url = 'http://............/member/login'
# 登录的参数
params = {
    
    
    "mobile_phone": 183000000000,
    "pwd": 12345678
}
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
response = requests.post(url=url, json=params, headers=headers)
res = response.json()
token = res['data']['token_info']['token']
print(token)

通过jsonpath提取

from jsonpath import jsonpath
import requests


url = 'http://............/member/login'
# 登录的参数
params = {
    
    
    "mobile_phone": 183000000000,
    "pwd": 12345678
}
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
response = requests.post(url=url, json=params, headers=headers)
res = response.json()

token = jsonpath(res,'$..token')
print(token)
token_type = jsonpath(res,'$..token_type')
print(token_type)

jsonpath的语法

$ 根节点:最外层是根节点
. or [] 取子节点:下一个节点
… 子孙节点:除根节点外所有节点
[] 如数组下标,根据内容选值

json模块

json.load:将json文件读取到python中

import json
from jsonpath import jsonpath


# json文件读取到python中
with open('ceshi.json','r',encoding='utf-8')as f:
    res = json.load(f)
# 类型为dict
print(type(res))
print(res)
# 使用jsonpath获取字典中reg_name数据
res = jsonpath(res,'$..data[reg_name]')
print(res)

json.loads:将json字符串转换成python数据的字典(与response.json()效果一致)

import requests
import json


url = 'http://..................../login'
# 登录的参数
params = {
    
    
    "mobile_phone": 183000000000,
    "pwd": 12345678
}
headers = {
    
    
    'X-Lemonban-Media-Type': 'lemonban.v2'
}
response = requests.post(url=url, json=params, headers=headers)
res = response.text
print(type(res),res)
res = json.loads(res)
print(type(res),res)
print()
res = response.json()
print(type(res),res)
下面是我整理的2023年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

生命力的意义在于拼搏,因为世界本身就是一个竞技场,就是无数次被礁石击碎又无数闪地扑向礁石,生命的绿荫才会越长越茂盛。

人生的每一刻,都是在为自己的明天铺路。要知道,逆风的方向,更适合飞翔,你觉得吃力,恰巧就是登高。

生活不能等待别人来安排,要自己去争取和奋斗,而不论其结果是喜是悲,但可以慰藉的是,你总不枉在这世界上活了一场。

猜你喜欢

转载自blog.csdn.net/m0_70102063/article/details/129818182