jmeter笔记9_正则表达式提取器

jmeter笔记9_正则表达式提取器

上一篇 / 下一篇  2010-12-03 14:59:45 / 个人分类:Jmeter相关

运用Jmeter正则提取器,可以从请求的响应结果中取到需要的内容,从而实现关联。下面简单介绍一下Jmeter正则表达式提取器的使用方法。

1、添加Jmeter正则表达式提取器

在具体的Request下添加Jmeter正则表达式提取器(Jmeter正则表达式在“后置处理器”下面)

2Jmeter正则表达式提取器控制面板,截图如下:

 

 

位置1:名称及注释

位置2:正则表达式提取内容的范围。(关于各字段的详细说明请查阅协议的相关说明)

位置3:正则表达式提取的相关设置

Ø 引用名称:其他地方引用提取值的变量名称,如填写的是:str,具体的引用方式是${str}

Ø 正则表达式:提取内容的正则表达式【稍注意一下:()表示提取,对于你要提前的内容需要用小括号括起来】

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

Ø 匹配数字(0代表随机)0代表随机,-1代表所有,其余正整数代表将在坚持的内容中,第几个匹配的内容提取出来。

Ø 缺省值:正则匹配失败时,取的值

下面举一个使用正则表达式提取内容的例子:

先向百度发送一个查询请求,查询的关键字:Jmeter,然后取返回页的title内容,作为下一个向百度发请求的关键字。(这例子没啥实际作用,只是为了练习Jmeter正则表达式提取器使用)

step_1:添加第一个http请求【请求的名字就叫:第1个请求】,即普通的http请求,访问百度,主要参数设置如下:

服务器名称或IP:www.baidu.com

方法:GET

路径:/s

同请求一起发送的参数:

             名称                                 

              wd                                 Jmeter

step_2:在第1个请求下面添加一个正则表达式提取器控件,参数设置同前面截图,这里简单说明一下:

引用名称:str

正则表达式:<title>(.*?)</title>

模板:$1$

匹配数字(0代表随机)1

缺省值:test

step_3:添加第2http请求【名字叫:第2个请求】,主要参数设置如下(留意参数wd的值)

服务器名称或IP:www.baidu.com

方法:GET

路径:/s

同请求一起发送的参数:

             名称                                 

              wd                                 ${str}

step_4:添加一个插口结果树,查看具体的请求情况

step_5:运行线程组,查看结果

 

【说明】

1、在使用正则表达式提取器的过程中,如果匹配数字选择的是-1,还可以通过${str_1}的方式来取第1个匹配的内容,${str_2}来取第2个匹配的内容。匹配数字和${str_n}可以好像可以相互替代,但究竟是不是这样的,还没弄太明白。

2、关于正则**?是不一样的,在上述的例子中使用正则<title>(.*?)</title>或者正则<title>(.*)</title>都是可行的。这个是正则中的贪婪与非贪婪模式,以后在正则相关日志中作说明。

以上参考:


 1、http://www.cnblogs.com/quange/archive/2010/06/11/1756260.html

2、http://blog.youkuaiyun.com/zhangren07/archive/2010/10/15/5944158.aspx
### 如何在 JMeter 中使用正则表达式提取器及其引用方法 #### 什么是正则表达式提取器正则表达式提取器JMeter 提供的一个功能强大的组件,主要用于从服务器返回的响应中提取所需的数据[^1]。通过定义特定的正则表达式模式,可以精确匹配目标数据并将其存储到变量中以便后续使用。 --- #### 配置正则表达式提取器的关键参数 以下是配置正则表达式提取器时需要设置的主要字段: 1. **名称 (Name)** 给提取器指定一个易于识别的名字,方便管理测试计划中的多个提取器[^3]。 2. **应用范围 (Apply to)** 定义正则表达式作用于哪个部分的内容,默认情况下可以选择 `Body` 或其他选项(如 Headers)。如果仅需处理响应体,则保持默认值即可[^4]。 3. **正则表达式 (Regular Expression)** 输入用于匹配目标数据的具体正则表达式。例如,在 HTML 响应中查找 `<input>` 标签内的属性值可采用如下形式: ```regex <name=(.+?)\svalue=(.+?)> ``` 4. **模板 (Template)** 指定如何解析匹配结果。通常格式为 `$n$`,其中 n 表示捕获组编号。对于上述例子,若希望分别保存 name 和 value 的值,则模板设为 `$1$$;$2$`[^2]。 5. **匹配序号 (Match No.)** 如果存在多个符合条件的结果,可以通过此参数选择具体哪一项作为最终输出。负数表示随机选取其中之一;0 则意味着返回所有可能的匹配项列表[^1]。 6. **默认值 (Default Value)** 当没有任何满足条件的数据被找到时所使用的替代字符串。这有助于防止因缺失预期信息而导致脚本失败[^3]。 --- #### 实际操作案例分析 假设我们正在开发一款登录页面的功能测试场景,并希望通过正则表达式提取 CSRF Token 来完成安全校验流程。已知该令牌嵌套在一个隐藏输入框内,形似下面这段代码片段: ```html <input type="hidden" id="_csrf_token" name="token" value="abcde12345"> ``` 此时可以根据实际需求设计相应的正则表达式与模板组合实现自动化抓取过程: - 正则表达式:`<input.*?id="_csrf_token".*?value="(.*?)">` - 模板:`$1$` 随后将提取出来的 token 存储至自定义变量 `${CSRF_TOKEN}` 下面,从而允许在整个线程组范围内重复调用它参与动态交互逻辑构建工作流[^4]。 --- #### 调试技巧推荐 为了提高效率减少错误发生概率建议遵循以下几个原则来进行前期准备工作: - 将完整的 HTTP 请求单独运行一遍并将完整结果复制粘贴下来; - 运用第三方网站或者插件辅助验证初步构思好的规则准确性; - 只有当确认无误之后才正式集成回原项目文件当中去执行下一步骤动作[^3]。 --- ```python import re # 示例 Python 代码展示简单的正则匹配原理 response_text = &#39;<input type="hidden" id="_csrf_token" name="token" value="abcde12345">&#39; pattern = r&#39;<input.*?id="_csrf_token".*?value="(.*?)">&#39; # 对应前面提到过的正则表达式 match_result = re.search(pattern, response_text) if match_result: csrf_token_value = match_result.group(1) print(f&#39;Extracted CSRF Token: {csrf_token_value}&#39;) else: print(&#39;No matching pattern found.&#39;) ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值