jmeter关联

一、Jmeter关联的方式:
  Jmeter中关联可以在需要获取数据的请求上 右键–>后置处理器 选择需要的关联方式,如下图有很多种方法可以提取动态变化数据:
在这里插入图片描述
二、正则表达式提取器:
  1、比如需要提取如下响应文本中的 “百度一下,你就知道” 里面的 “百度一下,你就知道”:
在这里插入图片描述
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进行使用。

### JMeter关联的用法及实现方式 #### 什么是关联? 在 JMeter 测试中,关联是一种重要的技术,用于处理动态参数。动态参数指的是服务器响应中的某些字段,这些字段可能会随着每次请求而变化,例如会话 ID、令牌(Token)、订单号等[^2]。为了确保后续请求的有效性和准确性,需要从上一次响应中提取这些动态参数,并将其传递到下一个请求。 --- #### 关联的主要作用 1. **动态会话参数处理**:如 Session ID 或 Token 的管理。 2. **服务器返回的数据依赖**:如订单号、验证码等,可能需要用于后续接口调用。 3. **提高测试的准确性**:通过动态参数替换静态值,避免因硬编码而导致请求失败。 --- #### 实现关联的方法 以下是几种常见的实现方法及其具体操作: ##### 方法一:正则表达式提取器 (Regular Expression Extractor) 正则表达式提取器是最常用的工具之一,适用于 HTML 和 XML 响应格式。它可以通过编写正则表达式来匹配目标字段并提取其值。 ###### 示例: 假设服务器返回如下 JSON 数据: ```json { "code": "0", "msg": "success", "data": { "token": "abcde12345" } } ``` 如果需要提取 `token` 字段,则可以按照以下步骤配置正则表达式提取器: - 右键单击 HTTP 请求 -> 添加 -> 后置处理器 -> 正则表达式提取器。 - 配置项: - 名称为:`regex_token` - 正则表达式:`"token"\s*:\s*"([^"]+)"` - 模板:`$1$` - 匹配编号:`1` - 默认值:`NOT_FOUND` 这样就可以将 `token` 提取出来,并存储为变量 `regex_token`。 --- ##### 方法二:JSON 路径提取器 (JSON Path Extractor) 对于 JSON 格式的响应数据,推荐使用 JSON 路径提取器。它可以更直观地定位所需字段。 ###### 示例: 继续以上述 JSON 数据为例,若要提取 `token` 字段,可以按以下步骤配置 JSON 路径提取器: - 右键单击 HTTP 请求 -> 添加 -> 后置处理器 -> JSON 路径提取器。 - 配置项: - 变量名称:`json_token` - JSON 路径表达式:`$.data.token` - 默认值:`NOT_FOUND` 此时,`token` 将被提取并存储为变量 `json_token`[^4]。 --- ##### 方法三:CSS/JQuery 提取器 当面对复杂的 HTML 页面时,CSS/JQuery 提取器可以帮助快速定位特定元素的内容。 ###### 示例: 假如页面中有如下结构: ```html <div id="session-id">abcdefg</div> ``` 如果想提取 `id` 属性对应的值,可以配置 CSS/JQuery 提取器: - 右键单击 HTTP 请求 -> 添加 -> 后置处理器 -> CSS/JQuery 提取器。 - 配置项: - 名称:`css_session_id` - CSS/JQuery 表达式:`div#session-id` - 属性:无 - 匹配编号:`1` - 默认值:`NOT_FOUND` 最终,`abcdefg` 将作为变量 `css_session_id` 存储下来。 --- ##### 方法四:XPath 提取器 针对 XML 格式的响应数据,可以使用 XPath 提取器进行解析和提取。 ###### 示例: 假设有如下 XML 数据: ```xml <response> <status>OK</status> <sessionId>xyz789</sessionId> </response> ``` 如果需要提取 `<sessionId>` 的值,可以按以下步骤配置 XPath 提取器: - 右键单击 HTTP 请求 -> 添加 -> 后置处理器 -> XPath 提取器。 - 配置项: - 名称:`xpath_session_id` - XPath 查询语句:`/response/sessionId/text()` - 默认值:`NOT_FOUND` 这一步完成后,`xyz789` 将被赋值给变量 `xpath_session_id`[^3]。 --- #### 如何验证提取结果? 在实际测试过程中,建议添加“查看结果树”监听器,以便观察提取后的变量值是否正确。可以在调试采样器或日志中打印变量内容,确认其已被成功捕获。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值