Jmeter--正则表达式提取器

正则提取器的一般使用场景是, 在我第二个请求参数中需要加入第一个请求的返回值, 此时通过正则提取器可以提取第一个请求返回值中指定的字段信息并赋值, 在第二个请求参数中直接引用该变量即可

jmeter的正则提取器截图如下:

 

这里写图片描述
简单介绍下其中几个比较重要的字段的信息, 如下表

 接下来看下实际的使用,

 


如图所示, 取登录后返回的ticket值, 此时因为方便说明, 使用"(.*?)"来获取返回值中双引号之间的内容:
这里写图片描述
添加debug元件, 展示debug信息如下,
这里写图片描述
此时, ${ticket}表示取的是第一列的值, 第一列是由模板上的$1$确定的,
此时Match No设置为-1 ,表示会返回所有匹配值数组的元素, 可以看到返回有三个元素分别为${ticket_1},${ticket_2},${ticket_3} 此时, 若有多行数据, 且模板处设置的为$1$, 如果选择第一个数组元素, 则:
• ${ticket_1_g0}取的都是第一个匹配值的第一列全部的数据
• ${ticket_1_g1}取的是第一个匹配值的第一列第一行的数据,
• ${ticket_1_g2}取的是第一个匹配值的第一列第二行的数据,
* ${ticket_2_g1}取的是第二个匹配值的第一列第一行的数据,

再来看一个比较简单的正则, 如下, 只取匹配值中的第一个元素:
这里写图片描述
这里写图片描述
Match No设置为1 , 表示只会选择返回的匹配值数组当中的第一个元素, 直接使用${ticket}表示即可, 此时, 若有多行数据, 且模板处设置的为$1$, 则:
• ${ticket_g0}取的都是第一列全部的数据
• ${ticket_g1}取的是第一列第一行的数据,
• ${ticket_g2}取的是第一列第二行的数据,
---------------------
Jmeter中关联可以在需要获取数据的请求上 右键-->后置处理器 选择需要的关联方式,如下图有很多种方法可以提取动态变化数据:  

  

 

二、正则表达式提取器:

   1、比如需要提取如下响应文本中的 “<title>百度一下,你就知道</title>” 里面的 “百度一下,你就知道”:

  

  2、设置正则表达式提取器:

  

   说明:

  (1)引用名称:下一个请求要引用的参数名称,如填写title,则可用${title}引用它。

  (2)正则表达式:

    ():括起来的部分就是要提取的。

    .:匹配任何字符串。
    +:一次或多次。
    ?:不要太贪婪,在找到第一个匹配项后停止。

  (3)模板:用$$引用起来,如果在正则表达式中有多个正则表达式,则可以是$2$$3$等等,表示解析到的第几个值给title。如:$1$表示解析到的第1个值

  (4)匹配数字:0代表随机取值,1代表全部取值,通常情况下填0

  (5)缺省值:如果参数没有取得到值,那默认给一个值让它取。

 

  3、使用2中获取到的值:

  

 

三、关于正则表达式的举例说明:

  1、提取单个字符串:
    假如想匹配Web页面的如下部分:name = "file" value = "readme.txt">并提取readme.txt。一个合适的正则表达式:name = "file" value = "(.+?)">。
      ():封装了待返回的匹配字符串。
      .:匹配任何单个字符串。
      +:一次或多次。
      ?:不要太贪婪,在找到第一个匹配项后停止。

  2、提取多个字符串:
    假如想匹配Web页面的如下部分:name = "file.name" value = "readme.txt">并提取file.name和readme.txt。一个合适的正则表达式:name = "(.+?)" value = "(.+?)"。这样就会创建2个组,分别用于$1$和$2$

  比如:

    引用名称:MYREF
    模板:$1$$2$

   如下变量的值将会被设定:
    MYREF:     file.namereadme.txt
    MYREF_g0:   name = "file.name"value = "readme.txt"
    MYREF_g1:  file.name
    MYREF_g2:  readme.txt

  在需要引用地方可以通过:${MYREF}, ${MYREF_g1进行使用。

 

Java正则表达式方法

这里就不对Java正则表达式的使用做基础学习了,下面列出了我们在进行“关联”操作时,需要掌握的基本元字符: 
( ) :将 () 之间括起来的表达式定义为“组”(group),并且将匹配这个表达式的字符保存到一个临时区域,我们主要就是利用这个元字符配合所指定的字符串匹配规则来进行匹配信息的提取; 
.+: 一个以上的任意字符,通过Greediness(贪婪型)匹配策略进行表达式模板的匹配(最大匹配); 
.+?:通过?元字符表示一个非贪婪模式匹配,即通过 Reluctant(勉强型)匹配策略进行表达式模板的匹配(最小匹配); 
另外,还包括.*,.*?,\d,\D,\w,\W等。

 

参考:https://www.cnblogs.com/LiangHu/p/6230372.html

转载于:https://www.cnblogs.com/klb561/p/10189197.html

<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、付费专栏及课程。

余额充值