jmeter--提取响应正文的json数据

本文介绍如何使用JMeter的JSONExtractor从响应中提取特定JSON数据。通过实例演示了提取数组中指定元素的方法及根据键值对匹配数据的技术。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jmeter提取json数据 一

如果有这么一个json数据:

{
“employees”: [
{ “firstName”:”John” , “lastName”:”Doe” },
{ “firstName”:”Anna” , “lastName”:”Smith” },
{ “firstName”:”Peter” , “lastName”:”Jones” }
]
}

在json中,对象用花括号括起来’{}’,数组用方括号括起来’[]’,假如我们要取到第二个lastName的值,如果字典中取就是employees 的value是一个数组,数组索引1的lastName的value值 ,在python中取就是dict[‘employees’][1][‘lastName’]。

在jmeter中,对应请求返回的数据是json格式的,可以通过后置处理器的JSON Extractor去提取json格式的数据:$.employee[1].lastName,可以取到第二个lastName的值。

在接口测试中,如果需求提取上个接口的json返回数据中的某个值并传给下一个接口作为请求参数。可以通过这种方法去取到数据。
图片1
图片2

最后运行结果成功!
图片3

jmeter提取json数据二

还是上面的那组数据,假如提取数据的需求是这样的:根据firstName的值去取对应的lastName的值,保证他们是匹配的

最开始想到的是json extractor中用两个这样的表达式提取:$.employee[*].firstName;$.employee[*].lastName,但是这种取法取的不是匹配的。后来想了下,用下面这种方法就可以实现:
图片4
再新增一个json extractor ,在json path expressions填入$.data[*] 。备注:这个json数据是用的我自己的接口测试的。原有的另一个json extractor中在json path expressions输入框写成$.id;$.name,在jmeter variable输入框中填入da变量,并选中,表示前面json extractor提取的data列表某一组数据,并传给下面的json extractor中使用 ,如下图:
图片5

运行结果:
图片6

<think>嗯,用户想了解如何使用JMeter的正则表达式提取器来提取token。首先,我需要回顾一下相关知识。根据引用[3],正则表达式提取器是后置处理器的一种,用于从取样器的响应结果中提取内容。用户需要的是具体步骤和示例。 首先,我应该列出使用步骤。根据引用[1]和[2],步骤包括添加提取器、配置参数、引用变量。然后,需要具体说明每个参数的设置,比如引用名称、正则表达式模板等。引用[4]提到变量引用的方式,所以最后要说明如何使用${token}。 接下来是示例部分。用户需要一个实际例子,比如登录接口返回的JSON中包含token。这时候正则表达式应该怎么写?比如"token":"(.*?)",这样贪婪匹配。左右边界要明确,确保正确提取。可能需要处理多个匹配,但用户可能只需要第一个,所以模板$1$。 还要注意常见问题,比如正则表达式是否正确,是否处理了特殊字符,或者是否需要转义。引用[2]中的疑难杂症部分可以提到这些,比如左右边界不确定怎么办,或者多个值的情况。此外,可能需要建议测试正则表达式是否有效,比如使用调试取样器。 最后,生成相关问题,比如如何提取多个值,或者JSON提取器的比较,这样用户如果有进一步的问题可以继续探索。确保回答结构清晰,步骤明确,示例具体,这样用户能跟着操作。</think>### JMeter正则表达式提取提取Token使用方法 #### 一、操作步骤 1. **添加取样器**:在需要提取Token的HTTP请求下添加取样器(如登录接口)[^3]。 2. **添加正则表达式提取器**:右键点击取样器 → 添加 → 后置处理器 → 正则表达式提取器[^1]。 3. **配置参数**: - **引用名称**:自定义变量名(如`token`) - **正则表达式**:根据响应内容编写,如`"token":"(.*?)"` - **模板**:`$1$`(表示提取第一个捕获组) - **匹配数字**:`1`(取第一个匹配项) - **缺省值**:`NOT_FOUND`(可选) ```plaintext 示例配置: 引用名称: token 正则表达式: "token":"(.*?)" 模板: $1$ 匹配数字: 1 ``` 4. **引用变量**:在后续请求中使用`${token}`调用提取值,如请求头中添加`Authorization: Bearer ${token}`[^4]。 --- #### 二、实际应用示例 **场景**:登录接口返回JSON数据: ```json {"code":200, "data":{"token":"abc123xyz"}, "msg":"success"} ``` **正则表达式配置**: - 精确匹配:`"token":"([^"]+)"` 解释:匹配双引号内的任意引号字符 - 通用匹配:`"token":"(.*?)"` 解释:贪婪模式匹配最短内容 --- #### 三、注意事项 1. **特殊字符转义**:若响应内容包含`\`或`"`,需使用`\`转义,如`\\"token\\":\\"(.*?)\\"` 2. **调试技巧**: - 使用`Debug Sampler`查看提取结果 - 在`View Results Tree`中检查响应数据格式 3. **性能优化**:正则表达式尽量具体,避免`.*`过度匹配[^2] ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值