首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【性能工具】Jmeter之关联详解

【性能工具】Jmeter之关联详解

作者头像
Luga Lee
发布2022-03-25 14:15:46
8680
发布2022-03-25 14:15:46
举报
文章被收录于专栏:架构驿站架构驿站
  • 正则表达式提取器

在需要获得数据的上一个请求上右击添加一个后置处理器-->正则表达式提取器

解释:

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

(2)正则表达式:

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

.匹配任何字符串。

+:一次或多次。

?:不要太贪婪,在找到第一个匹配项后停止。

(3)模板:用

引用起来,如果在正则表达式中有多个正则表达式(多个括号括起来的东东),则可以是引用起来,如果在正则表达式中有多个正则表达式(多个括号括起来的东东),则可以是$2

3

(4)匹配数字:0代表随机取值,1代表全部取值,通常情况下填0,如果在LR中,取出的值是一个数组,还得处理一下,LR11版本用一个随机的函数就可以不用写大段的代码来处理数组。

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

举例说明:

1、提取单个字符串:

假设测试人员期望匹配Web页面的如下部分:name = "file" value = "readme.txt">并提取readme.txt。

一个符合要求的正则表达式:name = "file" value = "(.+?)">。

():封装了待返回的匹配字符串。

.:匹配任何字符串。

+:一次或多次。

?:不要太贪婪,在找到第一个匹配项后停止。

2、提取多个字符串:

假设测试人员期望匹配Web页面的如下部分:name = "file" value = "readme.txt">并提取file和readme.txt。

一个符合要求的正则表达式:name = "(.+?)" value = "(.+?)"。

引用名称:MYREF

模板:12

如下变量的值将会被设定:

MYREF_g0:name = "file"value = "readme.txt"

MYREF_g1:file

MYREF_g2:readme.txt

引用${MYREF_g1}

使用该关联的请求,如下图:

  • XPath Extractor

XPath Extractor是另一个可被用来提取页面给定内容的Post Processor,XPath Extractor的使用方式与Regular Expression Extractor类似,只不过需要在该Extractor中指定的不是正则表达式,而是给定的XPath路径。

用xpath从前一个请求中取。这种形式比较适合于返回为xml片段的情况。在需要获得数据的请求上右击添加一个后置处理器-->xPath Extractor。引用名称即下一个请求要引用的参数名称,如填写body,则可用${body}引用它。

Xpath一般用于返回xml用得多。

XPath Extractor的设置界面:

Use Tidy?:当需要处理的页面是HTML格式时,必须选中该选项,当需要处理的页面是XML或XHTML格式(例如,RSS返回)时,取消选中该选项。

Reference Name:存放提取出的值的参数。

XPath Query:用于提取值的XPath表达式。

Default Value:参数的默认值。

两种方式汇总

正则表达式提取器和XPath Extractor都可以用来提取给定页面中的特定文本,并将其保存在参数中,这两种方式各有优缺点。

正则表达式提取器可以用于对页面任何文本的提取,提取的内容是根据正则表达式在页面内容中进行文本匹配;

而XPath Extractor则可以提取返回页面任意元素的任意属性。

相比较而言,如果需要提取的文本是页面上某元素的属性值,建议使用XPath Extractor;而如果需要提取的文本在页面上的位置不固定,或者不是元素的属性,建议使用正则表达式提取器。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2015-04-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 架构驿站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档