Jmeter Cookie或token跨线程组参数化
1、跨线程组设置全局变量(此变量每个线程用的都是同一个)
以下均以登录后进行查询作为示例:
(1)、取Cookie
BeanShell 后置处理程序设置全局变量
${__setProperty(getJSESSIONID,${JSESSIONID},)}
(2)第二个线程组设置cookie:(这里需要注意域是写域名或者IP地址,不用写端口号,浏览器F12也可见对应的域和路径是多少)
${__property(getJSESSIONID)}
使用察看结果树查看效果:可见每次请求的cookie是同一个(即最后一次设置全局变量的那个请求的cookie),不符合并发需求(每次都应不一样)
设置全局变量的另一种脚本:
String getToken=bsh.args[0];
print(getToken);
${__setProperty(Token,${getToken},)};
2、跨线程组先保存对应的cookie,后面的线程组再引用此cookie(此变量每个线程用的都是唯一一个cookie)
(1)使用取样器进行cookie文件预处理(必须保证后面线程组保存cookie的时候是全新的文件,最简单的就是删除同名的文件,后面重新生成)
ps:可以使用JSR223 前置处理程序,但是这个必须是放在请求(取样器)中才会生效。
import java.nio.file.*;
Path path = Paths.get("D:\\JSESSIONIDs.csv");
Files.deleteIfExists(path);
效果:每次运行后,D:\JSESSIONIDs.csv都是新的
(2)第二个前置线程组把每次登录的cookie储存下来:使用JSR223 后置处理程序,其他同上。
//存放数据路径,追加文件加true,覆盖文件不加
FileWriter fstream = new FileWriter("D:\\JSESSIONIDs.csv",true);
BufferedWriter out = new BufferedWriter(fstream);
//token 需要保存的数据名称,trim()去空格
out.write(vars.get("JSESSIONID")+"\n");
out.close();
fstream.close();
(3)第三线程组使用CSV 数据文件设置,进行引用:
运行后查看结果树的效果:每次都唯一
至此,已全部完成。
设置token跨线程组参数化就是把对应的cookie替换成token即可(token的值一般是在data中找,即响应文本;cookie则在信息头中)