【Jmeter】线程组内参数传递以及跨线程组参数传递的方法

本文介绍如何在JMeter中实现线程间参数传递,包括使用JSONExtractor从API响应中提取token,并通过BeanShellPostProcessor将其设置为属性,以便在后续线程组中使用。

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

线程组内参数传递

后一个api的调用需要用到前一个api返回的某些信息,这时候就需要提取出前一个api中某些信息。这里演示两个api,第一个api会产生一个token,然后第二个api需要带上这个token执行。

api写好之后,右键添加一个后置处理器 JSON Extractor,然后填入变量名称和response body中需要提取的字段,需要提取auth中client_token的值,jmeter中具体写法为$.auth.client_token

{
  "request_id": "7dbe69f4-bc82-feea-4e29-b91d33fb6374",
  "lease_id": "",
  "renewable": false,
  "lease_duration": 0,
  "data": null,
  "wrap_info": null,
  "warnings": null,
  "auth": {
    "client_token": "s.XPladcapF3**************",
    "accessor": "mrW5l8pi7Yf5WEET9GrEom41",
    "policies": [
      "root"
    ],
    "token_policies": [
      "root"
    ],
    "metadata": null,
    "lease_duration": 0,
    "renewable": false,
    "entity_id": "",
    "token_type": "service",
    "orphan": false
  }
}

在这里插入图片描述
在下一个api中,添加需要用到的变量,这样就可以实现参数传递了
在这里插入图片描述
但是这种方法不适合跨线程,下面介绍跨线程的参数传递,如果需要查看提取的值是否正确,可以添加一个Debug Sampler
在这里插入图片描述

跨线程组参数传递

思路:jmeter中,属性是全局的,是可以动态设置的;而变量是独属于每个线程的

两个api分别位于一个线程组,create secret需要用create token产生的token,首先还是需要给create token添加一个后置处理器,这一步和上面一样
在这里插入图片描述
接着需要再创建一个后置处理器 BeanShell PostProcessor,然后添加如下代码,将上一步提取出来的变量设置成一个属性
在这里插入图片描述
上面这个函数可以查看jmeter的函数助手,打开函数助手对话框,选到对应的函数,然后在函数参数那里填入相应的值,点击生成按钮,就会生成需要的语句
在这里插入图片描述
之后在下一个线程组的api中可以读取这个属性的值,同样,写法可以参考函数助手,这样就实现了跨线程组传递参数
在这里插入图片描述
还可以参考这个链接 https://www.cnblogs.com/allening/p/11650208.html

### JMeter跨线程参数传递及 HTTP Cookie 管理 #### 实现跨线程参数传递 为了实现不同线程组之间共享变量,在JMeter中可以利用`BeanShell 后置处理器`来设置全局属性。当需要在线程间传输特定数据(比如登录后的Token),可以通过JSON解析工具如`JSON Extractor`提取所需信息并存储为局部变量,之后再将其转化为全局可用的形式。 对于具体操作而言: - 利用 `JSON Extractor` 从服务器响应内容抽取目标字段(例如 token),并将之保存至名为 "token" 的本地变量中[^2]。 ```json { "data": { "auth_token":"example-token-value" } } ``` - 接着配置 BeanShell PostProcessor 来读取这个临时变量,并把它注册成一个可以在整个测试计划范围内访问的属性: ```java // 将 Thread Group A 提取出的数据转存为公共属性 props.put("sharedToken", vars.get("token")); ``` 上述代码片段会把之前提到的 `"token"` 变量值赋给一个新的全局属性 `"sharedToken"` ,这样其它任何地方都能通过 `${__P(sharedToken,)}` 或者直接使用`${sharedToken}`的方式引用该值了。 #### 处理 HTTP Cookies 跨线程传播 针对HTTP Session相关的Cookie信息同步问题,则建议采用稍微不同的策略。一种常见做法是在必要的位置单独实例化多个`HTTP Cookie Manager`件而不是依赖单一全局性的管理器[^3]。 具体步骤如下: - 移除项目级别上的默认HTTP Cookie Manager; - 在各个独立工作的Thread Groups内部各自引入新的HTTP Cookie Managers; - 特别地,在负责初始化Session的那个前置Setup Thread Group结束处附加一段BeanShell脚本逻辑,用来捕获当前有效的Cookies集合,并同样借助于Properties机制广播出去供后续环节消费。 示例代码展示如何收集指定名称下的所有cookies并通过环境变量形式分发: ```java import org.apache.jmeter.protocol.http.control.CookieManager; import java.util.Map; // 获取当前上下文中所有的cookie映射表 Map<String, String> cookies = ((CookieManager) ctx.getCurrentSampler().getTestElement()).getCookies(); for (String key : cookies.keySet()) { props.put(key, cookies.get(key)); } ``` 此段脚本遍历由关联的HTTP Request Sampler所携带的所有Cookie项,并逐条记录下来成为可被其他部分检索到的公共资源。 最后一步就是在那些期望接收这些预设好的session状态的地方重新加载对应的cookie设定。这通常意味着要在相应的HTTP请求前再次调用`__P()`函数注入先前准备完毕的各项cookie参数[^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值