Jmeter(五):json提取器元件及jsonpath介绍,响应断言元件

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快    

Jmeter:son提取器元件及jsonpath介绍

json提取器元件介绍

json提取器与正则表达式提取器功能类似,也是用来截取响应信息的部分保 存到指定的变量中去,不同的是,它只能用来处理响应正文,并且响应正文必须 是json格式的。它的优势是能更快更灵活的截取json格式文本中的内容。json提 取器在jmeter5.2.1版本中部分字段没有汉化过来。

路径:右击http请求——后置处理器——json提取器

如下图所示:

json提取器元件字段介绍

名称/注释:自定义的描述性文字

APPly to:作用范围 

  Main sample and sub-samples: 作用于主节点的取样器及对应子节点的取样器

  Main sample only:仅作用于主节点的取样器

  Sub-samples only:仅作用于子节点的取样器

  JMeter Variable Name to use:作用于jmeter变量(输入框内可输入jmeter的变量名称),从指定 变量值中提取需要的值

Names of created variables:Jmeter变量的名称

JSON Path expressions:调试通过的json path表达式;常用的表达式为$.标签名、$.标签名[0].标签名;详情见下面的jsonpath介绍

Match Numbers:匹配数字(0代表随机,1代表第一个,-1代表所有),默认不 填写是获取符合条件的第一个,与正则表达式类似

Compute comcatemation var(suffix_ALL):如果发现许多结果,插件将使用“,” 分隔符将它们连接起来,并将其存储在名为_ALL的var中

Default Values:当没有获取到参数值时的默认值

备注:

当json提取器要提取两个值(或两个以上)的时候,一定要填写默认值,不然会报错“Mismatch between number of variables, json expressions and default values”

JsonPath介绍

JsonPath 是一种信息抽取类库,是从JSON文档中抽取指定信息的工具, 在Python、Java、Javascript等编程语言中都有相应的类库提供。jmeter的json 提取器元件就可以使用jsonpath语法来截取json文档的内容。

json数据视图展示的地址:https://www.bejson.com/

jsonpath语法如下:

  $:表示根目录

  .:表示下一节点

  ..:表示任意一个节点

举例如下:

$.nums : 其中$代表根目录,这个表达式能取出10

$.tags[0].name: 遇到数组,使用[下标] ,这个表达式能取出 新梦想

$..name:任意节点中有name的值,则取第一个值;这个表达式也能取出 新梦想

在使用requests发送接口请求时,使用jsonpath时,jsonpath返回的是列表形式

Jmeter:响应断言元件

响应断言元件介绍

响应断言元件的功能是对接口的响应信息进行自动断言校验,来判断接口测 试得到的接口返回值是否正确。jmeter中该元件支持将请求或响应的各个字段与 模式字符串进行比较。有了该元件,就可以完成自动化接口测试,而不需要用手 工核对接口返回的结果

路径:右击http请求——断言——响应断言

展示如下:

响应断言元件字段介绍

名称/注释:自定义描述性文字

APPly to:作用范围

  Main sample and sub-samples:作用于主节点的取样器及对应子节点的取样器

  Main sample only:仅作用于主节点的取样器

  Sub-samples only: 仅作用于子节点的取样器

  JMeter Variable Name to use: 作用于jmeter变量(输入框内可输入jmeter的变量名称),从指定 变量值中提取需要的值

测试字段:要进行断言的响应字段选择,支持请求信息、响应信息等,其中响应 文本表示通过Apache Tika从各种类型的文档中提取文本

忽略状态:取样器的总体成功取决于断言结果与现有的响应状态的结合,当选择 “忽略状态” 复选框时,响应状态被强制成功,再进行本次断言评估

一个请求有多个响应断言,当第一个断言设置该选项,那么如果第一个断言失败后,第二个断言成功,事务还是成功状态(最后的断言必须勾选)

模式匹配规则:

1、包括 - 如果文本包含正则表达式模式,则为true

2、匹配 - 如果整个文本与正则表达式模式匹配,则为true

3、相等(Equals)- 如果整个文本等于模式字符串,则为true(区分大小写)

4、字符串(Substring) - 如果文本包含模式字符串,则为true(区分大小写)

5、否 - 反转检查结果,用于表示不包含,不匹配,不等于,没有和模式字符串 相匹配的Substring。

6、或者 - 一个断言可以添加多个“要测试的模式”。使用OR选项后,只要其中 有1个模式匹配,断言将会成功。不选择“OR”时将默认为AND选项,必须所 有模式都匹配,断言才会成功。

要测试的模式:输入结果期望值,可以增加多行期望结果

自定义失败消息:设置自定义的断言失败消息来替换系统默认的失败提示信息。

实战举例:

响应文本:判断返回的body中是否有7200;如下图

响应代码(响应状态码):判断响应的状态码是否为200;如下图

响应信息: 判断响应headers中是否为OK;如下图

响应头:判断响应headers中的信息是否有指定的信息;如下图

请求头:判断请求头中是否有指定的信息;如下图

URL样本:判断url里面是否有指定的信息;如下图

 

写在最后

 最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

 

### JMeter 并发测试中使用 JSON 提取器的方法 在进行并发测试时,JMeter 可以通过多种方式处理响应数据并从中提取所需的信息。对于基于 JSON 的 API 响应,可以利用 `JSON Extractor` 来解析和获取特定字段的内容。 #### 启动 JMeter 测试计划 为了运行包含 JSON 提取逻辑的脚本,可以通过直接双击 JMeter 安装目录下的 bin 文件夹中的 jmeter.bat 文件,或者通过命令行输入 java -jar ApacheJmeter.jar 来启动 JMeter[^1]。 #### 配置 HTTP 请求采样器 当设置好环境之后,在线程组内添加一个HTTP请求采样器用于发送针对目标服务器的具体请求。确保此请求返回的数据是以 JSON 形式存在的,因为这将是后续应用 JSON 提取器的基础。 #### 添加 JSON 提取器 接着向同一个控制器下增加一个新的后处理器组件——即 "JSON Extractor" 或者更现代的选择可能是 "JSON JMESPath Extractor"[^3]。配置该插件时需指定要匹配的变量名称以及对应的 JSON 路径表达式,以便能够准确定位到想要抓取的数据项。 例如,如果希望从如下结构体中抽取 id 字段: ```json { "data": { "id": 123, "name": "example" } } ``` 那么可以在 JSON Path 表达式的框里填入 `$..id` ,并将 Reference Name 设置为你期望存储这个值的名字比如 `userId`. #### 应用所提取的结果 一旦成功设置了上述步骤,则在整个测试过程中每当有新的响应到来都会自动触发相应的提取动作,并把得到的新值赋给预先定义好的变量名。这些被保存下来的参数就可以供后面的断言、调试或是其他类型的进一步操作使用了。 #### 执行非 GUI 模式下的性能测试 最后,若打算批量执行多个场景或长时间持续监控的话,建议采用无面模式来进行压测作业。此时可通过类似这样的指令完成整个流程:`jmeter -n -t test_demo.jmx -l result.jtl -e -o /Users/xxx/Desktop/ResultReport` [^2].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值