Python接口自动化之接口依赖

一、场景说明

在面试接口自动化时,经常会问,其他接口调用的前提条件是当前用户必须是登录状态,如何处理接口依赖?

在此之前我们介绍过session管理器保存会话状态。如果接口请求需要携带token,那么又如果处理呢?以下详细介绍。

未登录状态下,直接请求充值接口的异常场景:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

import unittest

import requests

class TestRecharge(unittest.TestCase):

    def setUp(self):

        pass

    def tearDown(self):

        pass

    def test_recharge(self):

        url = 'http://127.0.0.1:8888/recharge'

        payload = {

            "member_id": 100004312,

            "amount": 80

        }

        res = requests.post(url,json=payload)

        print(res.json())

if __name__ == '__main__':

    unittest.main()

运行结果如下:

{'code': 1003, 'msg': '未授权或token已过期'}

二、token处理思路

在处理之前,token灵魂三连问:

  • 如何获取token?
  • 获取的token如何管理?
  • 其他接口如何携带token?

思路如下:

1.抽取登录接口返回值中的token;

2.使用全局变量存储token。token可以存到yaml或者json或者ini的配置文件里,以下介绍将token作为类属性;

3.其他接口将token值放入请求头,发送请求;

三、JsonPath基本用法

我们需要从登录接口中提取出token,这里介绍JsonPath基本用法。

1、JsonPath介绍

JsonPath为Json文档提供了解析能力,通过使用JsonPath,你可以方便的查找节点、获取想要的数据,JsonPath是Json版的XPath。

2、JsonPath语法

JsonPath说明
$文档根元素
@当前元素
.[]匹配下级元素
..递归匹配所有子元素
*通配符,匹配下级元素
[]下标运算符,根据索引获取元素,JsonPath索引从0开始
[,]连接操作符,将多个结果拼接成数组返回,可以使用索引或别名
[start:end:step]数据切片操作
?()过滤表达式

这么多语法规范,大家会觉得一脸懵逼吧,细心的小伙伴会发现语法中 .. 表示递归匹配所有子元素,简单粗暴,用..获取所有匹配的子元素,通过索引拿到想要的值,以下以实战进行演练。

3、JsonPath源码

1

2

def jsonpath(obj, expr, result_type='VALUE', debug=0, use_eval=True):

    """traverse JSON object using jsonpath expr, returning values or paths"""

obj: 需要解析的对象,比如接口的返回值。

expr: 匹配的表达式。

4、JsonPath实战

以下编写代码进行演示。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

from jsonpath import jsonpath

# json格式结果

res = {

    "code": 0,

    "msg": "OK",

    "data": {

        "token_info": {

            "token_type": "Bearer",

            "expires_in": "2020-05-28 13:07:29",

            "token": "eyJhbGciOiJIUzUxAiJ9.eyJtZW1iZZJfaWQiOjEwMDA1MTMxNSwiZXhwIjoxNTkwNjQyNDQ5fQ.s6A7pzLILf9tqpEDAU9wIPGGLGkgKEQ6EBHq26l-eUM5seCb48DWalkE7u16iRZv3uzD5hIDFbw41Jmi9V0T_Q"

        }

    }

}

# 获取res中的token

token = jsonpath(res,'$..token')[0]

print(token)

响应结果为:

eyJhbGciOiJIUzUxBiJ9.eyJtZW1iZZJfaWQiOpEwMDA1MTMxNSwiZXhwIjoxNTkwNjQyNDQ5fQ.s6A7pzLILf9tqpEDAU9wIPGGLGkgKEQ6EBHq26l-eUM5seCb48SWalkE8u16iRZv3uzD5hIDFbw41Jmi9V0T_Q

四、token依赖实例

①在config/setting.py配置文件中,配置全局的域名或IP。

1

2

3

4

class DevConfig():

    # 项目的域名或IP

    host='http://127.0.0.1:8888'

config = DevConfig()

②在config/config.yaml文件中,存入登录账号。

config.yaml

1

2

3

user:

  mobile_phone: '155********'

  pwd: '12345678'

③在项目根目录下,新建文件夹middleware,文件夹下新建文件helper.py,用于处理token。

图片

④首先编写登录接口,返回接口数据。

helper.py

1

2

3

4

5

6

7

8

9

from common.requests_handler import RequestsHandler

from config.setting import config

from common.yaml_handler import yaml_data

def login():

    """登录,接口返回token"""

    req = RequestsHandler()

    res = req.visit('post', config.host+'/login', json=yaml_data['user'])

    return res

print(login())

运行结果如下:

{
'code': 0,
'msg': 'OK',
'data': {
'token_info': {
'token_type': 'Bearer',
'expires_in': '2020-05-26 13:31:41',
'token': 'eyJhbGciOiJIUpUxMiJ9.eyJtZW1iZXJfaWQiOjEwMDA1MTMxNSwiZXhwIjoxNTkwNDcxMTAxfQ.4QDNdQ-Wyecvpv7yRnMlCx1ZXpAlb8vpohxHht5OfNcjGn_yTaISyhmn7OMzjMGlz68sJ_uFbCh2NhIaO2p_Lg'
}
}
}

⑤接下来编写函数,获取登录接口返回值并提取token和token_type进行拼接 。这里要使用jsonpath模块提取返回的token和token_type。

helper.py

1

2

3

4

5

6

7

8

def save_token():

    """保存token信息"""

    res = login()

    token = jsonpath(res,'$..token')[0]

    token_type = jsonpath(res,'$..token_type')[0]

    token = " ".join([token_type, token])

    return token

print(save_token())

运行结果如下:

1

Bearer eyJhbGciOJIPzUxMiJ9.eyJtZW1iZXJfaWQiOjEwMDA1MTMxNSwiZXhwIjoxNTkwN

⑥最后定义类,将token作为类属性,整体代码如下:

helper.py

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

from common.requests_handler import RequestsHandler

from config.setting import config

from common.yaml_handler import yaml_data

from jsonpath import jsonpath

def login():

    """登录,返回token信息"""

    req = RequestsHandler()

    res = req.visit('post', config.host+'/login', json=yaml_data['user'])

    return res

def save_token():

    """保存token信息"""

    res = login()

    token = jsonpath(res,'$..token')[0]

    token_type = jsonpath(res,'$..token_type')[0]

    token = " ".join([token_type, token])

    Context.token = token

    return token

class Context:

    """将token作为类属性"""

    token = ''

if __name__ == '__main__':

    print(save_token())

运行结果如下:

Bearer eyJhbGciOiJIUzUxMiJ9.eyJtZW1iZXJfaWQiOjEwMDA1MTMxNSwiZXhwIjoxNTkwNDcz

⑦充值接口携带token请求。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

import unittest

import requests

from middleware.helper import Context, save_token

class TestRecharge(unittest.TestCase):

    def setUp(self):

        pass

    def tearDown(self):

        pass

    def test_recharge(self):

        save_token()

        token = Context.token

        url = 'http://127.0.0.1:88888/recharge'

        payload = {

            "member_id": 100051315,

            "amount": 80

        }

        res = requests.post(url,json=payload)

        print(res.json())

if __name__ == '__main__':

    unittest.main()

运行结果为:

{
'code': 0,
'msg': 'OK',
'data': {
'leave_amount': 240.0,
'mobile_phone': '155********',
}
}

​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:485187702【暗号:csdn11】

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 希望能帮助到你!【100%无套路免费领取】

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/753149.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

绿色再生·安卓4G智能远程操作巡视机器人小车

一、前言 1.1 项目介绍 【1】项目功能介绍 随着物联网技术与移动通信技术的快速发展,远程遥控设备在日常生活及工业应用中的普及度日益提高。无论是家用扫地机器人实现自主导航清扫,还是目前抖音平台上展示的实景互动小车等创新应用,都体现…

Games101笔记-模型、视图、投影

在旋转点,旋转矩阵的逆等于矩阵的转置 视图变换和投影变换 三维变换 左边3*3是线性变换,右边一列是仿射变换(平移) 先线性再平移 缩放、旋转、平移 x叉乘y得到z,y叉乘z得到x, xyz给任何两个可以得到另一个 (循环对称) z叉乘x得…

sqllab第十一关通关笔记

知识点: 发现登录框就可以尝试注入登录框一般都是字符型注入通过注入可以获取其他表的信息绕过手段 单引号闭合联合注入也可以进行错误注入 首先看界面是一个登录框;通过admin admin登录进去,发现页面会把用户名和密码的登录信息打印出来&am…

美区PayPal绑visa卡注意事项

很多小伙伴都有绑定paypal的需求,但是如果你是绑定美区的paypal这里有几点建议: 1、建议使用US的网络环境注册 2、使用美区的账号 3、使用美区的visa卡 三者统一才可以绑定成功,点击获取可以绑定美区paypal的visa卡,办理简单

【vue elementUI】修改el-dropdown样式

实现效果如下&#xff1a; 代码如下&#xff1a; <el-dropdown trigger"click" command"handleCommand" active-text-color"#606266"><span class"product-card">{{getCategoryName(categoryId)}}</span><el-dro…

docker安装华为opengauss高斯数据库

opengauss高斯数据库 openGauss是一款企业级开源关系型数据库&#xff0c;由华为公司推出。它深度融合了华为多年的数据库领域经验&#xff0c;充分结合企业级场景需求&#xff0c;基于openGauss自研生态而打造。 在架构上&#xff0c;openGauss着重于传统数据库的企业级能力和…

Monorepo 解决方案 — 基于 Bazel 的 Xcode 性能优化实践

背景介绍 书接上回《Monorepo 解决方案 — Bazel 在头条 iOS 的实践》&#xff0c;在头条工程切换至 Bazel 构建系统后&#xff0c;为了支持用户使用 Xcode 开发的习惯&#xff0c;我们使用了开源项目 Tulsi 作为生成工具&#xff0c;用于将 Bazel 工程转换为 Xcode 工程。但是…

sqllab第二十七关通关笔记

知识点&#xff1a; union select 关键字过滤 通过<> /**/进行截断处理 un<>ion sel<>ect 没效果uni/**/on sel/**/ect 被过滤了双写绕过 这关对select进行了多重过滤&#xff0c;无法进行双写绕过 大小写绕过 UNion SElect (这关可以用&am…

OpenvSwitch 配置 Trunk 端口实验

OpenvSwitch 配置 Trunk 端口实验 Open vSwitch(OVS)作为一款领先的软件交换机&#xff0c;为构建灵活、可扩展的虚拟网络架构提供了强大的支持。其中Trunk口(Trunk Port)功能就是OVS中一个非常实用的特性。 Trunk口允许在同一个物理端口上传输多个VLAN的数据流量。通过配置T…

西门子上位机软件WINCC的项目改造及其多元化报警功能实践:巨控GRM560智能远程控制终端

标签: #西门子WINCC #OPC通讯 #短信报警系统 #项目改造 #智能报警 西门子上位机软件WINCC的项目改造及其多元化报警功能实践 在工业自动化领域&#xff0c;有效的监控和及时的异常响应是保障生产安全和效率的关键。西门子的WINCC上位机软件升级&#xff0c;整合了巨控的OPC560…

Python 计算1~100 求和

result0 for i in range(101):print(i)result result i print(result)

Redis 内存是如何划分的?

查询内存命令 info memory 查询Redis自身使用内存的统计数据。通过这个命令&#xff0c;可以了解 Redis 实例的内存分配情况、内存碎片、键空间使用情况等 内存分配情况&#xff1a; used_memory&#xff1a;Redis 实例当前使用的内存总量&#xff08;以字节为单位&#xff0…

【初学者】Visual Studio 2019没有 C 项目,只有C++怎么办? 怎么创建第一个项目教程。

起因&#xff1a; 想要在 Visual Studio 上创建一个 C 项目&#xff0c;发现只有 C 的。 解决&#xff1a; C 是 C 的超集。只要创建 C 的项目就行了&#xff0c;将新增的 .cpp 文件改后缀为 .c 即可。不会有问题的。 C 的语法更加严格&#xff0c;而 C 的项目更宽松。虽然…

【云呐】固定资产管理系统的功能有哪些?管理工具

为了提高经营效率&#xff0c;降低企业成本&#xff0c;许多企业选择固定资产管理系统。那么&#xff0c;固定资产管理系统有什么作用呢&#xff1f; 资产登记&#xff1a;  固定资产管理系统可以方便地登记公司的固定资产&#xff0c;包括资产名称、规格型号、购买日期、使…

3dmax渲染卡光子、灯光缓存的处理方法

1、在vray全局开关勾选最大射线强度 2、将场景材质转换为vray类型 3、关闭置换 4、清理空物体等场景垃圾 可以试一下优化场景的工具&#xff0c;清理空物体、空代理、适当塌陷精简场景、清理场景垃圾等 有3dmax效果图渲染需求可以使用渲染100&#xff08;注册填邀请码‘7788…

微信小程序简单实现手势左右滑动和点击滑动步骤条功能

使用微信小程序实现左右滑动功能&#xff0c;自定义顶部图案&#xff0c;点击文字滑动和手势触屏滑动&#xff0c;功能简单&#xff0c;具体实现代码如下所示&#xff1a; 1、wxss代码&#xff1a; /* 步骤条 */ .tab-box {display: flex;flex-direction: row;position: fix…

DM数据库(docker)

docker安装 安装必要的系统工具 yum install -y yum-utils device-mapper-persistent-data lvm2 配置阿里云Docker Yum源: yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 更新yum缓存 yum makecache fast 安装docker-CE: y…

Issue 2046:Missing array size check in NewFixedArray

文章目录 环境搭建漏洞分析漏洞触发 漏洞利用总结参考 环境搭建 sudo apt install pythongit reset --hard 64cadfcf4a56c0b3b9d3b5cc00905483850d6559 export DEPOT_TOOLS_UPDATE0 gclient sync -D// debug version tools/dev/v8gen.py x64.debug ninja -C out.gn/x64.debug/…

FDA: 用于语义分割的傅里叶域自适应

论文链接&#xff1a;https://arxiv.org/abs/2004.05498 代码链接&#xff1a;GitHub - YanchaoYang/FDA: Fourier Domain Adaptation for Semantic Segmentation 机构&#xff1a;UCLA 发表于2020CVPR 这篇文章别的地方略读了&#xff0c;主要看看方法&#xff0c;感兴趣自…

如何理解“高频信息/高级语义”和“低频信息/低级语义”?

如何区分高频信息和低频信息&#xff1f; 如果一个东西是高度离散化和语义化的&#xff0c;一个字的差异也可能导致词语之间的含义发生重大变化&#xff0c;就是高频东西。例如一句话&#xff0c;如果你改变了一个单词&#xff0c;这个句子就会变成其他的意思。还有就是经过en…