jmeter--json提取器用法

JSON 提取器 是提取 响应体(response body)里的信息

一、使用场景:

 用在返回格式为json的http请求中,用来获取返回的json中的某个值,并保存成变量可供后面的请求调用。

二、配置说明:

1、添加路径: 后置处理器 -> JSON提取器
2、参数说明
在这里插入图片描述
1.Names of created variables: 自定义变量名,用于存放提取的数据。多个变量时用分号分隔。下一个请求使用时,可以用${变量名}引用它。

2.JSON Path expressions: json路径表达式,有多个表达式时用分号分隔。

  绝对路径:$.节点名称(复杂的:$.一级节点.二级节点.***.要提取的节点。
  相对路径:$..提取节点key。同级不同级但相同key值都被提取
  绝对路径和相对路径在获取多个值时的区别:
      用绝对路径获取的多个值,变量名都一样(自定义那个);
      相对路径获取的多个值,每个值都有一个变量名,变量名为 自定义的那个_下标,如返回3个值,自定义变量名为rspcode,那么三个值的变量名为rspcode_1, rspcode_2,rspcode_3。调用时需要哪个值可以用 ${rspcode_?}

3.Match No. (0 for Random):必填。0为随机取一个值,-1为提取所有值,其他正整数(n)为提取第n个值。有多个表达式时,用分号隔开
4.Compute concatenation var: 如果匹配到多个结果,将使用’ , '分隔符将它们连接起来,命名为“变量名_ALL”
5.Default Values:提取值为空时,返回这个设定的默认值。当Json表达式有两个及以上时,这个字段必填,有多少个表达式就要有多少个default value,用分号分隔

例如使用json提取器获取token
在这里插入图片描述

三、将提取的变量设置为全局变量

设置成全局变量后,跨线程也可调用了,具体方法如下:
1、添加后置处理器 -->BeanShell PostProcessor
2、用__setProperty()函数设置全局变量,即在BeanShell PostProcessor脚本输入框中添加函数
在这里插入图片描述
3、后面线程请求调用的时候,用__P()函数调用即可。
如HTTP请求的 HTTP信息头管理器中使用上面获取的token
在这里插入图片描述
这样变量就可跨线程调用了。

<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] ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值