29、OSPF配置实验之被动接口
349
2022-09-02
requests入门大全(requests的使用)
02 requests接口测试-requests的安装
安装常见问题
提示连接不上,443问题
一般是因为浏览器设置了代理,关闭代理。
网络加载慢,设置国内镜像地址
1.pip安装
2.pycharm安装
国内镜像源
清华:install -i pyspider,这样就会从清华镜像去安装pyspider库。
03 requests接口测试-requests原理与代码解析
requests工作原理
代码解析
通过追踪代码,可以发现requests实际上是调用了request方法,源码如下:
method, url是必填参数,其他是可选参数。
参数method,有GET, OPTIONS, HEAD, POST, PUT, PATCH, DELETE。
可选参数可以发送data、json、headers、cookies、flies、auth、timeout、proxies、verify、stream、cert
def request(method, url, **kwargs): """Constructs and sends a :class:`Request
04 requests接口测试-get请求
请求参数保存在url中,?后面添加参数名称和参数值,如果有多个参数,使用&连接请求参数保存在params中,params以字典形式保存数据
接口说明:
淘宝网
API地址: requestsdef test_get(): # 参数保存在url中,?后面添加参数名称和参数值,如果有多个参数,使用&连接 url = ' r=requests.get(url=url) print(r.text) print(r.status_code) print(r.cookies) print(r.url) # 参数保存在params中,params以字典形式保存数据 url = ' params={'tel':13909161860} r=requests.get(url=url,params=params) print(r.text) print(r.status_code) print(r.cookies) print(r.url)
获取响应结果
import requestsdef test_requests(): r = requests.get(' print('\n') print('状态码是:', r.status_code) print('url是:', r.url) print('头信息是:', r.headers) print('cookies是:', r.cookies) print('text是:', r.text) print('请求是:', r.request)
05 requests接口测试-post请求
post发送form格式请求参数,使用data
post发送json格式请求参数,使用json
06 requests接口测试-cookies值
什么是cookies?
相当于临时身份证。
谷歌浏览器抓包
查看请求参数的格式,看Content-Type字段
如:Content-Type: text/html;charset=utf8,表示请求参数是text格式,编码是utf-8
如果是form式,可以查看form data具体发送的参数
在脚本中发送
查看cookies
解码
编码:把码位转换成字节序列(通俗来说:把字符串转换成用于存储或传输的字节序列,python中是.encode())
解码:把字节序列转换成码位(通俗来说:把字节序列转换成人类可读的文本字符串,python中是.decode())
07 requests接口测试-headers值
headers参数不是每个接口都需要添加的,开发可以自行定义。
不需要添加headers
import requestsdef test_51job(): # 前程无忧搜索岗位不需要headers信息 url=' r_51job=requests.get(url=url) # print(r_51job.text) print(r_51job.encoding) # html默认的编码方式是ISO-8859-1 r_51job.encoding='gb2312' # 修改编码方式 print(r_51job.text)
乱码问题
需要添加headers
import requestsdef test_12306(): # 12306搜索车票需要添加headers信息,只需要cookies即可。实际工作中,headers需要哪些值,咨询开发人员了解。 url=' headers={'Cookie': 'JSESSIONID=C5DCA622147CEF2C4D9C3D3E53E9CF26; BIGipServerotn=1406730506.64545.0000; RAIL_EXPIRATION=1591740743186; RAIL_DEVICEID=FqtrEO_1lQCMdLmY_0uxjBNyLf5esH-V-KtA_I-kPu0j721_HYTxo4IobbdtZbAr75fLtGhLHAQTE8mWEaNmM7ococf3hUVIFw-Gaaper7CzwlrDFsHwwey8w_YQ5gGoMoyfKgVJ5o4nNuWVYhuiC_cxPzsWFJkF; BIGipServerpassport=954728714.50215.0000; route=6f50b51faa11b987e576cdb301e545c4; _jc_save_toStation=%u5E7F%u5DDE%2CGZQ; _jc_save_fromDate=2020-06-06; _jc_save_toDate=2020-06-06; _jc_save_wfdc_flag=dc; _jc_save_fromStation=%u4E0A%u6D77%2CSHH'} r_12306=requests.get(url=url,headers=headers) print(r_12306.text)
使用chrome查看headers
08 requests接口测试-requestsdef test_verify(): url=' r=requests.get(url=url,verify=False) print(r.text)
在verify里面添加证书路径
09 requests接口测试-上传文件files参数
携程上传头像
import requestsdef test_files(): url='# 携程上传头像 cookies={'cookie': 'cookies的值'} files={'uploadFile_852':('Markdown.jpg',open('D:\\Markdown.jpg','rb'),'image/jpeg')} r=requests.post(url=url,files=files,verify=False,cookies=cookies) print(r.text)
files字段说明:
uploadFile_852 文件参数的名字,通过抓包工具查看,实际工作中直接向开发咨询了解。
Markdown.jpg 文件名
open('D:\Markdown.jpg','rb') 打开本地一个文件,注意使用\转义
image/jpeg 文件格式
禅道上传csv文件
上传文件,你一般需要什么参数?
1.url
2.请求参数
3.请求方式
4.files参数
5.cookies
接口测试两个检查点
1.校验返回结果与开发定义的(接口文档)是否一致,如上传成功返回1,上传失败返回0
2.校验接口逻辑是否正确,如上传文件后会把文件保存在服务器的一个目录下,到该目录下检查是否存在上传的文件
10 requests接口测试-timeout超时
超时测试介绍
超时异常
requests.exceptions.ConnectTimeout: HTTPConnectionPool(host='tcc.taobao.com', port=80): Max retries exceeded with url: /cc/json/mobile_tel_segment.htm?tel=13909161860 (Caused by ConnectTimeoutError(
import requestsdef test_timeout(): url = ' r=requests.get(url=url,timeout=1) print(r.text)
轮循
import requestsdef test_files(): # 携程上传用户头像 for i in range(0,10): try: url=' cookies={'cookie': 'cookies的值')} r=requests.post(url=url,files=files,verify=False,cookies=cookies,timeout=0.25) print(r.text) except: print('运行出错')
11 requests接口测试-auth鉴权
12 requests接口测试-文件下载接口
导出禅道用例模板
思路
stream参数的使用
13 requests接口测试-session操作
为什么要使用session参数?
有很多接口需要一些公共的参数,比如cookies,可节省时间,精简代码
def test_seesion(): s=Session() s.headers={'h':'test_headers'} r=s.post('# 就不需要再单独添加headers print(r.json())
14 requests接口测试-token的操作
token放在data参数里
15 requests接口测试-sign签名
参数名ASCII码从小到大排序(字典序);
◆ 如果参数的值为空不参与签名;
◆ 参数名区分大小写;
第二步,在stringA最后拼接上key得到stringSignTemp字符串,并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。
举例:
假设传送的参数如下:
appid: wxd930ea5d5a258f4fmch_id: 10000100device_info: 1000body: testnonce_str: ibuaiVcKdpRxkhJA
第一步:对参数按照key=value的格式,并按照参数名ASCII字典序排序如下:
stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA";
第二步:拼接API密钥:
stringSignTemp=stringA+"&key=192006250b4c09247ec02edce69f6a2d" //注:key为商户平台设置的密钥keysign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A9CF3B7" //注:MD5签名方式sign=hash_hmac("sha256",stringSignTemp,key).toUpperCase()="6A9AE1657590FD6257D693A078E1C3E4BB6BA4DC30B23E0EE2496E54170DACD6" //注:HMAC-SHA256签名方式,部分语言的hmac方法生成结果二进制结果,需要调对应函数转化为十六进制字符串。
最终得到最终发送的数据:
proxies代理机制
proxies = {''''test_proxies(): r = requests.get(" # get请求带query参数 ,为 URL 的查询字符串(query string)传递某种数据 params={ 'a': 1, 'b': 2, 'c': 'asd' }, proxies=proxies, verify=False # 关闭校验,否则代理无法抓包 ) print(r.json())
hook机制
hook机制可修改响应返回的内容,或替换响应返回的内容。
import requestsdef test_get_hook(): def hook(r,*args,**kwargs): r.demo = 'demo content' r = requests.get(" params={ 'a': 1, 'b': 2, 'c': 'asd' }, hooks={'response': [hook]} ) print(r.json()) print(r.demo)
16 requests接口自动化--原则
尽量减少后期的维护成本
1.测试数据的维护
2.测试脚本的维护
尽量减少测试用例之间的依赖性覆盖的全面性易理解易阅读
规范命名
添加注释
最重要的一点是做自动化测试要基于公司的需求,从公司需求出发。
17 requests接口自动化测试-pom模块划分
18 requests接口自动化-自定义函数参数化
通过配置文件实现。
在实际工作中,可能需要在不同的测试环境测试,此时可以在配置环境定义好不同的环境,通过更改配置,达到在不同环境进行测试的目的。
配置文件
def server_ip(): # 配置文件,通过修改配置,在不同环境进行测试 dev_ip=' sit_ip=' return sit_ipdef sql_conf(): # 定义数据库的配置 ip='' username='' password='' port=3306 charset='utf-8' return ip,username,password,port,charset
import requestsfrom config.conf import * # 从config导入def test_conf(): url=server_ip()+'/login' # server_ip()表示引入这个函数,而不是这个方法 print(url) r=requests.get(url=url) print(r.text)import requestsfrom config.conf import * # 从config导入def test_conf(): url=server_ip()+'/login' # print(url) r=requests.get(url=url) print(r.text)
19 requests接口自动化-excel参数化
20 requests接口自动化-数据库参数化
21 requests接口自动化-列表与字典参数化
22 requests接口自动化-动态关联text/html格式
23 requests接口自动化-动态关联json格式
24 requests接口自动化-assert断言
25 pytest框架-安装
26 pytest框架-运行测试用例
27 pytest框架-动态关联
28 pytest框架-生成测试报告
29 Jenkins+requests+pytest+allure持续集成
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~