JMeter中如何实现接口之间的关联?

本文详细介绍了如何在JMeter中使用正则表达式提取器、JSONExtractor以及XPathExtractor进行动态数据关联,包括它们在处理session信息、参数传递和XML解析中的应用。作者还分享了两者之间的区别和实际场景中的使用建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关联是Jmeter工具中非常重要的一个技术。因为在测试过程过有些数据是经常发生变化的,要获取并使用这些数据,就要使用关联。
在这里插入图片描述

比如:用户登录后,session信息都不同,有些操作要使用session,就需要将这个动态的信息保存下来。还有经常遇到的场景,第二个请求提交的参数要从第一个请求的返回数据中获取。

具体方法:

一、正则表达式提取器

在默认的测试计划中添加一个线程组,然后添加取样器。在这里插入图片描述

右键添加后置处理器→正则表达式提取器,正则表达式提取器界面如下:
在这里插入图片描述

说明:

后置处理器:在请求结束或者返回响应结果时发挥作用

正则表达式提取器:允许用户从服务器的响应中通过使用perl的正则表达式提取值。该元素会作用在指定范围取样器,用正则表达式提取所需值,生成模板字符串,并将结果存储到给定的变量名中。

APPly to:作用范围(返回内容的断言范围)

Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器

Main sample only:仅作用于父节点的取样器

Sub-samples only:仅作用于子节点的取样器

JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)

要检查的响应字段:需要检查的响应报文的范围

主体:响应报文的主体

Body(unescaped):主体,响应的主体内容且替换了所有的html转义符,注意html转义符处理时不考虑上下文,因此可能有不正确的转换,不太建议使用

Body as a Document:从不同类型的文件中提取文本,注意这个选项比较影响性能

Response Headers:响应信息头

Request Headers:请求信息头

URL:统一资源定位符,即Internet上用来描述信息资源的字符串

响应代码:响应状态码,比如200、404等

响应信息:响应信息

引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的值、字段、变量名(例子中我提取的是SOCIAL_NO)

正则表达式(Regular Expression):使用正则表达式解析响应结果,“()”表示提取字符串中的部分值,请不要使用“||”,除非你本身需要匹配这个字符。

常用的正则表达式操作符:

在这里插入图片描述

模板:代表从正则表达式结果引用的样式,其实结果是一组,而不是一个。0 00代表这一组结果的全部,1 11代表这一组结果的第1个,以此类推;1 112 22代表该正则表达式一组结果中的第1个和第2个,俩结果挨在一起中间没有间隔;3 33,4 44代表该正则表达式一组结果中的第3个和第4个,俩结果间有一个逗号相连。

匹配数字:0代表正则表达式结果组中随机,1代表全部。

缺省值:当引用不对时显示传递的信息,通畅写一个ERROR。

最后,根据上面的说明,完成配置,然后可以先添加一个监视器(查看结果树),检查是否取到了对应的值;提取到的参数,调用时用s e s s i o n i d 1 , {sessionid_1},sessionid
1 ,{sessionid_2}…,如果想要得到匹配出的参数的个数,${sessionid_matchNr}。

二、json path postprocessor(JSON Extractor)

用处:当前接口响应返回的json中提取内容,作为变量可以在不同的请求中传递。如下,从登陆接口返回的json中提取user id,变量名设置为id,在其他请求中可以直接调用这个变量,或者作为post参数。次插件对于restful接口非常好用。
在这里插入图片描述

Variable names : 名称

JSONPath Expression:JSON表达式

Match Numbers:匹配哪个,可为空即默认第一个

Default Value:未取到值的时候默认值

比如返回值如下:

 
  1. 1 {

  2. 2 "userSession": {

  3. 3 "businessCode": "900000",

  4. 4 "createTime": "2018-05-25 03:24:17",

  5. 5 "userCode": "29feaa3c98014e02bec16c6f448a6459",

  6. 6 "userName": "lip-vpn",

  7. 7 "sessionId": "10a4cee035d044d8b2f25e2cebb2843e"

  8. 8 }

  9. 9}

则json表达式为:$.userSession.sessionId

如果返回值是数组,则需要加上数组的位置,如

  1. 1{

  2. 2 "userSession": [

  3. 3 {

  4. 4 "businessCode": "900000",

  5. 5 "createTime": "2018-05-25 03:24:17",

  6. 6 "userCode": "29feaa3c98014e02bec16c6f448a6459",

  7. 7 "userName": "lip-vpn",

  8. 8 "sessionId": "10a4cee035d044d8b2f25e2cebb2843e"

  9. 9 }

  10. 10 ]

  11. 11}

则json表达式为:$.userSession[0].sessionId,提取第一个值。

三、XPath Extractor

Jmeter提供的对关联的支持包括以下2个方面:

①能够将返回页面上的指定内容保存在参数中;(即正则表达式提取器和JSON Extractor)

②能够将GET或POST方法中的数据使用该参数来替换;(XPath Extractor)

XPath Extractor的使用方法与正则表达式提取器(Regular Expression Extractor)类似,只不过该Expression中指定的不是正则表达式,而是给定的XPath路径。

后置处理器(Post Processor)本质上是一种对sampler发出请求后接受到的响应数据进行处理(后处理)的方法。必须将后置处理器元件放在合适的位置才能达到预期的效果。

新建一个线程组,然后右键-添加-后置处理器-XPath Extractor:在这里插入图片描述

APPly to:作用范围(返回内容的断言范围)

  1. Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器

  2. Main sample only:仅作用于父节点的取样器

  3. Sub-samples only:仅作用于子节点的取样器

  4. JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)

XML Parsing Options:要解析的XML参数

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

Quiet表示只显示需要的HTML页面,Report errors表示显示响应报错,Show warnings表示显示警告;

Use Namespaces:如果启用该选项,后续的XML解析器将使用命名空间来分辨;

  1. Validate XML:根据页面元素模式进行检查解析;

  2. Ignore Whitespace:忽略空白内容;

  3. Fetch external DTDs:如果选中该项,外部将使用DTD规则来获取页面内容;

Return entire XPath fragment of text content:返回文本内容的整个XPath片段;

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

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

Default Value:参数的默认值。

正则表达式提取器和XPath Extractor的区别:

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

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

③如果需要提取的文本是页面上某元素的属性值,建议使用XPath Extractor;

④如果需要提取的文本在页面上的位置不固定,或者不是元素的属性,建议使用正则表达式提取器

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

<think>嗯,用户的问题是关于如何使用JMeter或Postman进行多接口关联测试并实现参数传递。我需要先回忆一下这两种工具的相关知识,然后结合用户提供的引用内容来组织答案。 首先,用户提到了JMeter和Postman,两者都是常用的接口测试工具。关联测试通常指的是后一个接口需要用到前一个接口的返回结果,比如token、ID等参数。用户提供的引用中有提到JMeter的正则表达式提取器,以及Postman的环境变量设置,这些应该是关键点。 对于JMeter部分,引用[2]和[4]提到了使用正则表达式提取器来获取前一个接口的响应数据,并传递给后续请求。可能需要详细说明如何添加后置处理器,比如正则表达式或者JSON提取器,然后通过变量名在后续请求中引用。例如,登录接口返回的token,通过正则表达式提取后,保存为变量,然后在下一个请求的header或参数中使用${token}。 Postman方面,引用[3]提到在Tests脚本中设置环境变量,使用pm.environment.set()方法,将响应数据中的值保存到环境变量中,后续接口可以直接通过变量名引用。比如在登录接口的Tests里提取token并保存,然后在后续请求的Authorization头中使用{{token}}。 用户可能需要具体的步骤,比如在JMeter中添加后置处理器,如何写正则表达式或JSON路径,变量的引用方式。同时,要比较两种工具的优缺点,帮助用户选择适合的场景。例如,JMeter适合性能测试和复杂逻辑,而Postman更适合调试和自动化流程。 还要注意用户的需求是多接口关联和参数传递,所以需要分步骤讲解,每个步骤的具体操作,可能还需要示例代码或截图。但根据用户提供的示例,他们希望有代码块,比如JMeter的配置截图或者Postman的脚本示例。 另外,用户提供的引用中有提到异步接口的例子,可能需要考虑接口之间的时序问题,比如异步执行后如何轮询状态,这里可能需要用到定时器或循环控制器。不过用户的问题可能更侧重于参数传递,这部分可以简要提及。 需要检查是否有遗漏的点,比如JMeter的JSON提取器、XPath提取器,或者Postman的Collection变量与环境变量的区别。同时,要强调测试的验证,比如断言是否正确获取了参数,确保数据传递的正确性,如引用[3]中的断言示例。 最后,生成相关问题,可能涉及性能测试中的关联、常见问题解决、参数化与关联的区别等,帮助用户深入理解。</think>### 使用 JMeter 或 Postman 实现接口关联测试的方法 #### **一、JMeter 实现接口参数关联** 1. **核心原理** 通过后置处理器(如正则表达式提取器或 JSON 提取器)从接口响应中提取参数,存储为变量供后续接口调用[^2][^4]。 2. **具体步骤** - **步骤1:添加 HTTP 请求** 创建多个接口请求(如登录、查询、删除等),并确保接口顺序符合业务逻辑。 - **步骤2:添加后置处理器** 在需要提取参数的接口后添加 **正则表达式提取器** 或 **JSON 提取器**。 - **正则表达式示例**(提取 token): ```text 引用字段:响应体 正则表达式:"token":"(.*?)" 变量名:token ``` - **JSON 提取器示例**(提取异步任务 ID): ```text JSON Path表达式:$.data.taskId 变量名:taskId ``` - **步骤3:参数传递** 在后续接口的请求参数或 Header 中通过 `${变量名}` 引用提取的值,例如: ```text Authorization: Bearer ${token} 请求体:{"taskId": "${taskId}"} ``` - **步骤4:添加断言** 使用响应断言验证参数传递是否成功,例如检查返回结果是否包含 `${taskId}`[^4]。 3. **异步接口关联示例** ```text 异步执行接口 → 正则提取 taskId → 异步查询接口(轮询) → 结果提取 → 删除接口 ``` --- #### **二、Postman 实现接口参数关联** 1. **核心原理** 利用环境变量或全局变量存储提取的参数,实现接口数据传递[^3]。 2. **具体步骤** - **步骤1:设置环境变量** 在 Postman 中创建环境变量(如 `dev_env`),用于存储动态参数。 - **步骤2:提取并保存参数** 在第一个接口的 **Tests** 标签中使用脚本提取数据并存入环境变量: ```javascript // 提取登录接口的 token const token = pm.response.json().token; pm.environment.set("token", token); ``` - **步骤3:跨接口调用参数** 在后续接口的请求参数或 Header 中通过 `{{变量名}}` 引用环境变量,例如: ```text Authorization: Bearer {{token}} ``` - **步骤4:断言验证** 添加断言确保参数正确传递: ```javascript pm.test("任务ID存在", () => { pm.expect(pm.response.json().taskId).to.eql(pm.environment.get("taskId")); }); ``` --- #### **三、工具对比与选型建议** | **场景** | **JMeter** | **Postman** | |------------------------|-----------------------------------------|---------------------------------------| | **性能测试** | ✅ 支持高并发和分布式测试 | ❌ 仅适合单请求调试 | | **复杂参数关联** | ✅ 支持正则、JSON、XPath 多种提取方式 | ✅ 依赖脚本灵活性高 | | **可视化操作** | ❌ 配置较复杂 | ✅ 界面友好,适合快速调试 | | **自动化流程** | ✅ 可通过线程组+逻辑控制器实现 | ✅ 支持 Collection Runner 和 Newman | --- #### **四、常见问题解决** 1. **JMeter 变量未生效** - 检查变量作用域(线程组/测试计划) - 使用调试取样器(Debug Sampler)查看变量值[^2] 2. **Postman 环境变量污染** - 使用 `pm.environment.unset("token")` 清理变量 3. **异步接口轮询** - 在 JMeter 中通过 **While 控制器** + **定时器** 实现轮询逻辑[^1] ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值