前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Groovy在JMeter中处理header

Groovy在JMeter中处理header

作者头像
FunTester
发布2020-04-03 15:29:31
1.4K0
发布2020-04-03 15:29:31
举报
文章被收录于专栏:FunTester

发现JMeter系列写了不少文章,干脆整个全套的,把剩下的Demo也发一下,旧文如下:

  • 用Groovy处理JMeter断言和日志
  • 用Groovy处理JMeter变量
  • 用Groovy在JMeter中执行命令行
  • 用Groovy处理JMeter中的请求参数
  • 用Groovy在JMeter中使用正则提取赋值
  • JMeter吞吐量误差分析

上一期已经讲过了JMeter如何处理cookie,文章如下:

  • Groovy在JMeter中处理cookie

这里先重复一个事实,cookie只是HTTP请求header里面的一个字段,但是在JMeter里面是分开处理的,HTTP信息头管理器HTTP Cookie管理器完全就是两个对象,分工不重复,在源码里面使用的是HeaderManagerCookieManager两个类。

首先讲一讲HeaderManager的基本使用,添加header,获取header,修改header

  • 首先新建一个简单的线程组和一个简单的请求:

Groovy在JMeter中处理header

  • 然后创建一个HTTP信息头管理器
  • 添加JSR223 预处理程序(后置处理程序需要下一次次请求)

脚本内容:

代码语言:javascript
复制
import org.apache.jmeter.protocol.http.control.*

def manager = sampler.getHeaderManager()
manager.add(new Header("FunTester","FunTester"))
def h = manager.get(0)
log.info("-------Header : " + h.getName() + "----------- " + h.getValue())
h.setValue("FunTester039029309230")
log.info("-------Header : " + h.getName() + "----------- " + h.getValue())```

* 控制台输出:

```Java
2020-03-19 21:08:23,928 INFO o.a.j.e.StandardJMeterEngine: Running the test!
2020-03-19 21:08:23,929 INFO o.a.j.s.SampleEvent: List of sample_variables: []
2020-03-19 21:08:23,930 INFO o.a.j.g.u.JMeterMenuBar: setRunning(true, *local*)
2020-03-19 21:08:24,059 INFO o.a.j.e.StandardJMeterEngine: Starting ThreadGroup: 1 : 线程组
2020-03-19 21:08:24,059 INFO o.a.j.e.StandardJMeterEngine: Starting 1 threads for group 线程组.
2020-03-19 21:08:24,060 INFO o.a.j.e.StandardJMeterEngine: Thread will continue on error
2020-03-19 21:08:24,061 INFO o.a.j.t.ThreadGroup: Starting thread group... number=1 threads=1 ramp-up=0 perThread=0.0 delayedStart=false
2020-03-19 21:08:24,062 INFO o.a.j.t.ThreadGroup: Started thread group number 1
2020-03-19 21:08:24,062 INFO o.a.j.e.StandardJMeterEngine: All thread groups have been started
2020-03-19 21:08:24,062 INFO o.a.j.t.JMeterThread: Thread started: 线程组 1-1
2020-03-19 21:08:24,101 INFO o.a.j.m.J.处理Header: -------Header : FunTester----------- FunTester
2020-03-19 21:08:24,102 INFO o.a.j.m.J.处理Header: -------Header : FunTester----------- FunTester039029309230
2020-03-19 21:08:24,271 INFO o.a.j.t.JMeterThread: Thread is done: 线程组 1-1
2020-03-19 21:08:24,271 INFO o.a.j.t.JMeterThread: Thread finished: 线程组 1-1
2020-03-19 21:08:24,271 INFO o.a.j.e.StandardJMeterEngine: Notifying test listeners of end of test
2020-03-19 21:08:24,271 INFO o.a.j.g.u.JMeterMenuBar: setRunning(false, *local*)

  • 查看结果树

  • 「郑重声明」:文章首发于公众号“FunTester”,禁止第三方(腾讯云除外)转载、发表。
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-03-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FunTester 微信公众号,前往查看

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

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

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