腾讯内部干货分享——JMeter中3种参数值的传递
小伙伴们在使用JMeter的过程中,肯定会遇到参数值传递的问题,下面来和大家总结下,在使用JMeter做压力测试的时候,常见的3种参数值得传递是怎样的。
(一)从CSV文件读取要批量输入的变量
假如我们要登录的数据保存在login.csv文件里,数据如下:
10001 |
pwd10001 |
---|---|
10002 |
pwd10002 |
10003 |
pwd10003 |
10004 |
pwd10004 |
10005 |
pwd10005 |
在JMeter中,我们需要添加“CSV Data Set Config”这个配置文件,如下图:
添加后,我们需要填写其中的必要参数,如Filename和Variable Names:
这里要注意下Variable Names里面的分隔符,为啥是用','号呢,因为csv文件login.csv用notepad++打开是如下所示,前面的字段是代表用户的user,后面的字段代表的pwd:
配置好CSV Data后,我们添加login的HTTP请求,截图如下:
其中用户的user和pwd都是用${}包围着的,这个是JMeter的语法规定。配置线程数为5,点击启动按钮运行后,看到的结果如下:
可以看到,login.csv文件中的2个字段被当作参数值进行了传递。
(二)利用Cookie进行值的传递
用JMeter进行接口调试时,有时候会遇到需要登录的情况,如请求wetest的DataSearchAjax接口:
返回的结果如下:
出现这种情况的原因很明显是未登录引起的。一个较好的解决方法就是将登录后的cookies保存下来,在访问DataSearchAjax接口的时候,带上用户登录后的cookies信息进行查看。
在JMeter中,我们可以通过如下途径进行cookies的传递,如下图添加HTPP Cookie管理器:
再给登录的接口添加前置处理器Bean Shell PreProcessor,用来保存登录的cookies:
下面,我们要在Bean Shell PreProcessor里面添加我们的cookies值了。
import org.apache.jmeter.protocol.http.control.CookieManager;
import org.apache.jmeter.protocol.http.control.Cookie;
// 身份验证必须的cookie值字段(可以询问开发哪些是必须要校验的字段)
// 可以在登录后,点击chrome里URL右边的查看网站信息按钮,查看所有的cookie值找到
// wetest的校验字段是:csrftoken和sessionid
CookieManager manager = sampler.getCookieManager();String csrftoken = "898b3ade5cb3744140503da601dee5d6793f82807cda581de9eb0982c05dfdc7a";
//定义Cookie对象,其中参数:cookie的名称, cookie值, cookie域, 路径, 安全Cookie cookie = new Cookie("csrftoken",csrftoken,"wetest.qq.com","/",false,0);
manager.add(cookie);String sessionid = "0ir0hrodptu5qgv9qurk98c3l4";
Cookie cookie1 = new Cookie("sessionid",sessionid,"wetest.qq.com","/",false,0);
manager.add(cookie1);
添加完HTPP Cookie管理器以及在前置处理器“Bean Shell PreProcessor”写好脚本后,再次运行登录接口和DataSearchAjax接口:
可以看到,后面的请求携带了我们在“Bean Shell PreProcessor”脚本中保存的cookie值,并且成功返回了要查询的数据。
(三)利用正则匹配提取上一个接口的返回数据作为下个请求的输入
用JMeter进行接口调试时,经常会遇到上一接口的返回值中的某个字段,要作为下一接口的输入,这种情况下,我们需要利用正则匹配来提取我们需要的值。
例如,若要提取相应数据中的goodpraise字段作为下个接口的输入的话,可以在该接口请求后面添加正则表达式提取器:
我们给正则表达式提取器命名为get_goodpraise,并填写引用名称、正则表达式、模板、匹配数值、缺省值,填写后的如如下:
填写完成后,在添加新的HTTP请求,来测试提取到的goodpraise_name字段:
这里要注意,${}里面填写的一样要是引用名称的变量,保存后执行:
若返回的请求goodpraise_name字段为-1,-1是我们设定的默认字段。那说明我们的正则表达式写错了,要仔细检查下改成正确的正则表达式,再执行:
可以看到,我们提取到的goodpraise_name字段成功传递给新的http请求。
至此,JMeter中3种参数值的传递已全部讲解完,小伙伴们学会了吗~
关于压力测试,腾讯WeTest有话说:WeTest压力简单模式已经上线啦!
简单模式主要是针对web类服务器提供压力源以及测试结果分析,业务场景模拟只要一分钟!详情可直接点击链接"压测简单模式"查看。
本文为腾讯WeTest授权发布
转载请申请授权
更多干货分享请关注《腾讯WeTest》公众号
关于腾讯WeTest
腾讯WeTest是腾讯游戏官方推出的一站式游戏测试平台,用十年腾讯游戏测试经验帮助广大开发者对游戏开发全生命周期进行质量保障 腾讯WeTest提供:兼容适配测试;云端真机调试;安全测试;耗电量测试;服务器压力测试;舆情监控等服务
↙点击下方“阅读原文”查看更多
- [WCF安全系列]谈谈WCF的客户端认证[Windows认证]
- ls命令实现分析
- [WCF安全系列]谈谈WCF的客户端认证[X.509证书认证]
- Openstack Trove概要
- [WCF安全系列]实例演示:TLS/SSL在WCF中的应用[SSL over TCP]
- [WCF安全系列]谈谈WCF的客户端认证[用户名/密码认证]
- [WCF安全系列]绑定、安全模式与客户端凭证类型:BasicHttpBinding
- [WCF安全系列]服务凭证(Service Credential)与服务身份(Service Identity)
- 如何正确的对安卓手机进行数据恢复?
- [WCF安全系列]绑定、安全模式与客户端凭证类型:WSHttpBinding与WSDualHttpBinding
- Python中list的遍历
- Python中的参数传递与解析
- [WCF安全系列]实例演示:TLS/SSL在WCF中的应用[HTTPS]
- QEMU3 - 使用ceph来存储QEMU镜像
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Java File类基础解析 1
- jit即使编译语言调用c++
- java JDBC系列1 JDBC类的简析与JDBC的基础操作
- TRTC Android端开发接入学习之常见问题(十一)
- 树莓派基础实验7:倾斜开关实验
- Hive SQL经典优化案例
- 树莓派基础实验8:振动开关实验
- 几行代码实现cookie的盗取
- 从apollo的初始化看spring boot 1.5.3启动过程( 一)
- CSRF(跨站请求伪造)学习总结
- windows mysql 8.0 ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO)
- 树莓派基础实验9:蜂鸣器实验
- 浅谈文件上传漏洞(客户端JS检测绕过)
- java字符串操作:如何实现字符串的反转及替换?
- 树莓派基础实验10:干簧管传感器实验