Jmeter 之正则表达式提取器应用

前言

说到Jmeter正则表达式提取器的应用,就不得不说到关联。所谓关联,就是把应用中动态变化返回的数据获取到,把它保存为一个参数,提供给后面需要用到的地方进行使用。

Jmeter中关联可以通过"添加---后置处理器---正则表达式提取器"来获取数据,且注意正则表达式提取器附在需要获取数据的某个采样器之下,数据一般从"查看结果树"的响应数据获取。

Jmeter中关联可以通过"添加---后置处理器---正则表达式提取器"来获取数据,且注意正则表达式提取器附在需要获取数据的某个采样器之下,数据一般从"查看结果树"的响应数据获取。

一、获取单个数据

举例:获取用户列表的结果如下,需要将"mobilephone":"158****1763" 手机号码取出用来进行登录操作

1、在获取用户列表请求下面添加---后置处理器---正则表达式提取器

正则表达式提取器说明:

**Apply to:**应用范围

**要检查的响应字段:**样本数据源。

**引用名称:**其他地方引用时的变量名称,我这里写的phone,可自定义设置,引用方法:${引用名称}

**正则表达式:**数据提取器,()括号里为你要获取的的值。"mobilephone":"( 相当于LR左边界, )","leaveamount"相当于LR右边界。而括号里\d+为正则表达式,用来匹配所需要获取的数据,何谓正则表达式文章末尾会附上说明

**模板:**用于从找到的匹配项创建字符串的模板。这是一个带有特殊元素的任意字符串,用于引用正则表达式中的组。引用组的语法是:' 1 '引用组1,' 2 '引用组2,等等。 0 引用整个表达式匹配的内容。

**匹配数字:**正则表达式匹配数据的所有结果可以看做一个数组,匹配数字即可看做是数组的第几个元素。-1表示全部,0随机,1第一个,2第二个,以此类推。若只要获取到匹配的第一个值,则填写1

**缺省值:**匹配失败时的默认值。可以不写。若需用于后续逻辑判断,可简单写为 ERROR。

2、在获取用户列表添加的 Debug PostProcessor 为调试所用,一般用于查看获取的变量值。

从执行结果中,能看到获取的值为如下:

3、在登录请求中,将正则表达式获取的值进行引用。

二、获取多个数据

举例:在用户列表的结果中,需要将"id":82,"mobilephone":"150****7414", 用户id、手机号码都取出用来进行后续登录、投资操作

1、注意如果包含多个正则,我们进行如下设置

其中,我们可以通过 Debug PostProcessor 来查看结果

从结果中,如果我们要引用id、mobilephone的话,也就是这里user_g1、user_g4分别指代的值。

2、注意变量值在登录、投资请求中的引用!

附正则表达式说明:

通俗点来讲正则表达式就是用来匹配字符串的公式。比如正则表达式中\d+ 是来匹配1个或更多连续的数字。更多可自行百度了解。

个人觉得非常非常细节的地方注意一下:

一,如果是post请求:

数据类型 : 如果是form类型 放在jmeter请求的 参数中

form类型
如果json类型 加信息头管理器

这一点很重要哦---

二,接口的入参都是有来源的

1、手动输入
2、从前面的接口的响应中来的

${__time(,)} --函数助手对话框,自动生成name---value ;

相关推荐
Wx-bishekaifayuan44 分钟前
基于微信小程序的社区图书共享平台设计与实现 计算机毕业设计源码44991
javascript·vue.js·windows·mysql·pycharm·tomcat·php
哎呀呦呵1 小时前
python内置模块-re模块介绍使用
java·python·mysql
wuyunhang1234563 小时前
MySQL----触发器
数据库·mysql
鸽鸽程序猿4 小时前
【MySQL】索引
数据库·mysql
川石课堂软件测试6 小时前
全链路Controller压测负载均衡
android·运维·开发语言·python·mysql·adb·负载均衡
hjbf7 小时前
理解并解决 MySQL 中的 "You can't specify target table for update in FROM clause" 错误
mysql
一路向北_Coding7 小时前
MyBatis Generator让你优雅的写SQL
mysql·mybatis
程序猿(雷霆之王)8 小时前
MySQL——复合查询
数据库·mysql
Zhsh-710 小时前
centos配置ES和MYSQL自动备份
mysql·elasticsearch·centos
尘下吹霜11 小时前
【鉴权架构】SpringBoot + Sa-Token + MyBatis + MySQL + Redis 实现用户鉴权、角色管理、权限管理
spring boot·mysql·mybatis