JMeter中3种参数值的传递

JMeter做压力测试的时,常见的3种参数值的传递方式

小伙伴们在使用JMeter的过程中,肯定会遇到参数值传递的问题,下面来和大家总结下,在使用JMeter做压力测试的时候,常见的3种参数值的传递是怎样的。

(一)CSV文件读取要批量输入的变量

假如我们要登录的数据保存在login.csv文件里,数据如下:

10001

pwd10001

10002

pwd10002

10003

pwd10003

10004

pwd10004

10005

pwd10005

JMeter中,我们需要添加CSV Data Set Config这个配置文件,如下图:

 

添加后,我们需要填写其中的必要参数,如FilenameVariable Names

 

这里要注意下Variable Names里面的分隔符,为啥是用','号呢,因为csv文件login.csvnotepad++打开是如下所示,前面的字段是代表用户的user,后面的字段代表的pwd

 

配置好CSV Data后,我们添加loginHTTP请求,截图如下:

 

其中用户的userpwd都是用${}包围着的,这个是JMeter的语法规定。配置线程数为5,点击启动按钮运行后,看到的结果如下:

 

可以看到,login.csv文件中的2个字段被当作参数值进行了传递。

(二)利用Cookie进行值的传递

  用JMeter进行接口调试时,有时候会遇到需要登录的情况,如请求wetestDataSearchAjax接口:

 

返回的结果如下:

 

出现这种情况的原因很明显是未登录引起的。一个较好的解决方法就是将登录后的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种参数值的传递已全部讲解完,小伙伴们学会了吗~*(^_^)*~

 

最新文章
1客户案例研究:专家安全扫描,守护金融银行小程序安全和私密性 WeTest私有化部署的定制扫描平台让金融银行客户能无成本接入扫描系统并迅速上手使用。客户能方便快捷地根据定制手册进行自助扫描,根据生成的扫描报告,详细洞察漏洞,快速识别并准确定位问题根源。
2客户案例研究:专家渗透测试,洞察电子商务小程序重大交易漏洞 通过WeTest渗透测试服务,某知名零售公司旗下的在线购物类小程序中发现了8处安全风险,我们的安全专家为客户提供了详细的漏洞报告,提供了较为清晰完整的安全加固方案。在回归测试中,中危以上风险均被解决。
3自查小程序4大安全隐患!文末免费赠送小程序安全扫描专业版! 腾讯WeTest现面向小程序开发者开放免费申请使用小程序安全扫描专业版,助您提前发现全面的安全漏洞。扫描文中问卷二维码或点击问卷链接,即可报名参与免费领取活动。
4浅谈渗透测试服务在泛互行业带来的价值 在泛互联网行业中,渗透测试服务对于保障企业的网络安全至关重要。
5云手机卡顿/无特定设备/商店登录受限怎么办?WeTest专有云帮您解决! 公有云满足了大量小微企业、个人的测试需求;随着客户深入使用,也遇到了一系列新问题。本篇将对几个常见问题予以解答
购买
客服
反馈