当前位置:网站首页>JMeter中如何实现接口之间的关联?
JMeter中如何实现接口之间的关联?
2022-07-17 01:59:00 【小梧敲代码】
关联是Jmeter工具中非常重要的一个技术。因为在测试过程过有些数据是经常发生变化的,要获取并使用这些数据,就要使用关联。
比如:用户登录后,session信息都不同,有些操作要使用session,就需要将这个动态的信息保存下来。还有经常遇到的场景,第二个请求提交的参数要从第一个请求的返回数据中获取。
具体方法:
一、正则表达式提取器
在默认的测试计划中添加一个线程组,然后添加取样器。
右键添加后置处理器→正则表达式提取器,正则表达式提取器界面如下:
说明:
后置处理器:在请求结束或者返回响应结果时发挥作用
正则表达式提取器:允许用户从服务器的响应中通过使用perl的正则表达式提取值。该元素会作用在指定范围取样器,用正则表达式提取所需值,生成模板字符串,并将结果存储到给定的变量名中。
APPly to:作用范围(返回内容的断言范围)
Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器
Main sample only:仅作用于父节点的取样器
Sub-samples only:仅作用于子节点的取样器
JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)
要检查的响应字段:需要检查的响应报文的范围
主体:响应报文的主体
Body(unescaped):主体,响应的主体内容且替换了所有的html转义符,注意html转义符处理时不考虑上下文,因此可能有不正确的转换,不太建议使用
Body as a Document:从不同类型的文件中提取文本,注意这个选项比较影响性能
Response Headers:响应信息头
Request Headers:请求信息头
URL:统一资源定位符,即Internet上用来描述信息资源的字符串
响应代码:响应状态码,比如200、404等
响应信息:响应信息
引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的值、字段、变量名(例子中我提取的是SOCIAL_NO)
正则表达式(Regular Expression):使用正则表达式解析响应结果,“()”表示提取字符串中的部分值,请不要使用“||”,除非你本身需要匹配这个字符。
常用的正则表达式操作符:

模板:代表从正则表达式结果引用的样式,其实结果是一组,而不是一个。 0 0 0代表这一组结果的全部, 1 1 1代表这一组结果的第1个,以此类推; 1 1 1 2 2 2代表该正则表达式一组结果中的第1个和第2个,俩结果挨在一起中间没有间隔; 3 3 3, 4 4 4代表该正则表达式一组结果中的第3个和第4个,俩结果间有一个逗号相连。
匹配数字:0代表正则表达式结果组中随机,1代表全部。
缺省值:当引用不对时显示传递的信息,通畅写一个ERROR。
最后,根据上面的说明,完成配置,然后可以先添加一个监视器(查看结果树),检查是否取到了对应的值;提取到的参数,调用时用 s e s s i o n i d 1 , {sessionid_1}, sessionid1,{sessionid_2}…,如果想要得到匹配出的参数的个数,${sessionid_matchNr}。
二、json path postprocessor(JSON Extractor)
用处:
当前接口响应返回的json中提取内容,作为变量可以在不同的请求中传递。如下,从登陆接口返回的json中提取user id,变量名设置为id,在其他请求中可以直接调用这个变量,或者作为post参数。次插件对于restful接口非常好用。
Variable names : 名称
JSONPath Expression:JSON表达式
Match Numbers:匹配哪个,可为空即默认第一个
Default Value:未取到值的时候默认值
比如返回值如下:
1 {
2 "userSession": {
3 "businessCode": "900000",
4 "createTime": "2018-05-25 03:24:17",
5 "userCode": "29feaa3c98014e02bec16c6f448a6459",
6 "userName": "lip-vpn",
7 "sessionId": "10a4cee035d044d8b2f25e2cebb2843e"
8 }
9}
则json表达式为:$.userSession.sessionId
如果返回值是数组,则需要加上数组的位置,如
1{
2 "userSession": [
3 {
4 "businessCode": "900000",
5 "createTime": "2018-05-25 03:24:17",
6 "userCode": "29feaa3c98014e02bec16c6f448a6459",
7 "userName": "lip-vpn",
8 "sessionId": "10a4cee035d044d8b2f25e2cebb2843e"
9 }
10 ]
11}
则json表达式为:$.userSession[0].sessionId,提取第一个值。
三、XPath Extractor
Jmeter提供的对关联的支持包括以下2个方面:
①能够将返回页面上的指定内容保存在参数中;(即正则表达式提取器和JSON Extractor)
②能够将GET或POST方法中的数据使用该参数来替换;(XPath Extractor)
XPath Extractor的使用方法与正则表达式提取器(Regular Expression Extractor)类似,只不过该Expression中指定的不是正则表达式,而是给定的XPath路径。
后置处理器(Post Processor)本质上是一种对sampler发出请求后接受到的响应数据进行处理(后处理)的方法。必须将后置处理器元件放在合适的位置才能达到预期的效果。
新建一个线程组,然后右键-添加-后置处理器-XPath Extractor:
APPly to:作用范围(返回内容的断言范围)
Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器
Main sample only:仅作用于父节点的取样器
Sub-samples only:仅作用于子节点的取样器
JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)
XML Parsing Options:要解析的XML参数
Use Tidy:当需要处理的页面是HTML格式时,必须选中该选项;如果是XML或XHTML格式(例如RSS返回),则取消选中;
Quiet表示只显示需要的HTML页面,Report errors表示显示响应报错,Show warnings表示显示警告;
Use Namespaces:如果启用该选项,后续的XML解析器将使用命名空间来分辨;
Validate XML:根据页面元素模式进行检查解析;
Ignore Whitespace:忽略空白内容;
Fetch external DTDs:如果选中该项,外部将使用DTD规则来获取页面内容;
Return entire XPath fragment of text content:返回文本内容的整个XPath片段;
Reference Name:存放提取出的值的参数。
XPath Query:用于提取值的XPath表达式。
Default Value:参数的默认值。
正则表达式提取器和XPath Extractor的区别:
①正则表达式提取器可以用于对页面任何文本的提取,提取的内容是根据正则表达式在页面内容中进行文本匹配;
②XPath Extractor则可以提取返回页面任意元素的任意属性;
③如果需要提取的文本是页面上某元素的属性值,建议使用XPath Extractor;
④如果需要提取的文本在页面上的位置不固定,或者不是元素的属性,建议使用正则表达式提取器。
最后感谢每一个认真阅读我文章的人,下面这个网盘链接也是我费了几天时间整理的非常全面的,希望也能帮助到有需要的你!

这些资料,对于想转行做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。希望对大家有所帮助……
如果你不想一个人野蛮生长,找不到系统的资料,问题得不到帮助,坚持几天便放弃的感受的话,可以点击下方小卡片加入我们群,大家可以一起讨论交流,里面会有各种软件测试资料和技术交流。
| 点击文末小卡片领取 |
敲字不易,如果此文章对你有帮助的话,点个赞收个藏来个关注,给作者一个鼓励。也方便你下次能够快速查找。
自学推荐B站视频:
零基础转行软件测试:自学完软件测试,拿到了字节的测试岗offer,堪称B站最好的视频!
边栏推荐
- 神经网络学习笔记2.2 ——用Matlab写一个简单的卷积神将网络图像分类器
- laravel的问题
- 如何将Excel中的数据粘贴到cxGrid中
- Shell script receives and returns parameters
- MySQL 增删查改(基础)
- leetcode:50. Pow(x, n)
- MYSQL主从搭建
- Cmake common commands
- About 1000base-t1 1000Base-TX and 100base-t1
- Chengxin University envi_ IDL second week homework: extract aerosol thickness at n points + detailed analysis
猜你喜欢

Gnome boxes virtual machine creation and installation
![Dqn theoretical basis and code implementation [pytoch + cartpole-v0]](/img/cf/32438e403544aa42e2fdd2e181327c.png)
Dqn theoretical basis and code implementation [pytoch + cartpole-v0]

options has an unknown property ‘before‘

代理模式——B站动力节点

Mouse slide two pictures before and after comparison JS plug-in

SwiftUI 考试题库项目之支持题库和考试题库数量(教程含源码)

Game theory of catching lice

Laravel's problem

第二章 线性表

About 1000base-t1 1000Base-TX and 100base-t1
随机推荐
Envi: (the most detailed tutorial in 2022) custom coordinate system
支持工业级瘦设备4G接入,润和软件DAYU120通过OpenHarmony兼容性测评
从 0 到 1 开展软件测试
上班摸鱼打卡模拟器微信小程序源码
leetcode:78. subset
[2016 CCPC 杭州J] Just a Math Problem (莫比乌斯反演)
Underline shortcut
基于MFC如何实现单个文档的文件读写
洛谷每日三题之第五天
MYSQL主从搭建
Chapter I Introduction
leetcode 222. Number of nodes of a complete binary tree (required)
10. Redis interview FAQ
oracle 查询 主机名和对应的IP地址
Chapter II linear table
options has an unknown property ‘before‘
oracle 查询非自增长分区的最大分区
論文閱讀:U-Net++: Redesigning Skip Connections to Exploit Multiscale Features in Image Segmentation
Simple usage and interface introduction of labelme
Installing PWA application in Google Chrome browser will display more description information