在Jmeter中的JSR223 PreProcessor使用javascript实战

重点:

1、jmeter中的jsr223 preprocessor中内嵌的javascript版本是ECMA 5.1,postman中可以执行的脚本(ECMA 6),过来需要进行降级实现(ECMA 5.1)

2、jmeter压测中的number of threads(users)代表并发数,ramp-up period(seconds)代表多少秒内发起users,duration(seconds)代表持续多长时间

可被执行的javascript代码:

//加载外部资源
load("https://www.xxx.com/crypto-js-3.1.2/core.js");
load("https://www.xxx.com/crypto-js-3.1.2/hmac.js");
load("https://www.xxx.com/crypto-js-3.1.2/enc-base64.js");
load("https://www.xxx.com/crypto-js-3.1.2/sha256.js");

//加密函数
function encryptSHA256(content, secret) {
  var hmac = CryptoJS.HmacSHA256(content, secret);
  return CryptoJS.enc.Base64.stringify(hmac)
}
//随机数函数
function getNonce(len) {
  // 密码字典
  var str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
  // 大写字母密码字典
  var bigStr = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  // 小写字母的密码字典
  var upperStr = 'abcdefghijklmnopqrstuvwxyz';
  // 数字的密码字典
  var numStr = '0123456789';
  var builder = '';
  var count = 0;
  var isContainBigChar = false;
  var isContainUpperChar = false;
  var isContainNumChar = false;
  while (count < len - 3) {
    //生成 0 ~ 密码字典-1之间的随机数
    var i = Math.floor(Math.random() * str.length);
    builder += str[i];
    count++;
    if (!isContainBigChar && bigStr.indexOf(str[i])!=-1) {
      isContainBigChar = true;
    }
    if (!isContainUpperChar && upperStr.indexOf(str[i])!=-1) {
      isContainUpperChar = true;
    }
    if (!isContainNumChar && numStr.indexOf(str[i])!=-1) {
      isContainNumChar = true;
    }
  }
  // 如果不存在的,则加,确保一定会存在数字,大写字母,小写字母
  if (!isContainBigChar) {
    builder += bigStr[Math.floor(Math.random() * bigStr.length)];
  }
  if (!isContainUpperChar) {
    builder += upperStr[Math.floor(Math.random() * upperStr.length)];
  }
  if (!isContainNumChar) {
    builder += numStr[Math.floor(Math.random() * numStr.length)];
  }
  while (builder.length < len) {
    builder += str[Math.floor(Math.random() * str.length)];
  }
  return builder;

}
//定义http头所需变量
var appKey = '350dd9d1e3fd425681df8cb1eccd4663';
var secretKey = '9fae5a9334a52718a6d9784b32857fb0e06251754f213ea04ce5cfaa8562caaa';

var timestamp = Date.now();
var nonce = getNonce(8);
//获取request内容
var sampler = ctx.getCurrentSampler ();
var args = sampler.getProperty ("HTTPsampler.Arguments");
var httpArg = args.getObjectValue ().getArguments ().get (0);
var jsonObject = httpArg.getObjectValue ().getProperty ("Argument.value").getStringValue ();

jsonObject.appKey=appKey;
jsonObject.timestamp=String(timestamp);
jsonObject.nonce=nonce;
jsonObject.xidList=JSON.stringify(jsonObject.xidList);
//5.1语法
var plainText = '';
for (x in jsonObject) {
	plainText += ''+x+'='+[x]+'&';
}
plainText = plainText.slice(0, -1);
//生成加密内容
var sign = encryptSHA256(plainText, secretKey);
//置入变量,在后续请求中使用该变量
vars.put("appKey",appKey)
vars.put("timestamp",timestamp)
vars.put("sign",sign)
vars.put("nonce",nonce)

感谢: teacher c,teacher w.

JMeter 5.5 中,JSR223 PreProcessor 无法正常工作的问题可能与脚本执行方式、语言选择或依赖配置有关。以下是一些常见原因及解决方案: ### 常见原因 1. **脚本语言支持问题** JSR223 PreProcessor 依赖于 Java 的脚本引擎,如 Groovy、JavaScript、BeanShell 等。如果使用的语言未正确配置或不被支持,脚本将无法执行[^1]。 - Groovy 是推荐的语言,因为它性能较好且与 Java 兼容性高。 - JavaScript 可能因 JVM 安全限制而受限。 - BeanShell 在 JMeter 5.4 之后被弃用,可能导致不稳定。 2. **脚本未正确编写或语法错误** JSR223 PreProcessor 不会自动捕获脚本错误,错误可能被静默忽略。建议在脚本中加入日志输出以便调试。 ```groovy log.info("This is a test log message") ``` 3. **缺少依赖库** 某些脚本语言(如 Python 或 Ruby)需要额外的依赖库才能运行。如果未将相关 JAR 文件放置在 `lib/ext` 目录下,脚本将无法执行。 4. **脚本未被触发** JSR223 PreProcessor 必须位于取样器(Sampler)之前,并且该取样器必须被执行,脚本才会运行。检查线程组配置、控制器结构以及取样器是否被禁用。 5. **JMeter 属性配置问题** 在某些情况下,JMeter 的全局属性可能影响脚本行为。例如: ```properties language=javascript ``` 如果在 `jmeter.properties` 或 `user.properties` 中设置了不兼容的默认语言,可能导致脚本执行失败。 ### 解决方案 1. **确认语言设置** 在 JSR223 PreProcessor 中显式选择 Groovy 作为脚本语言,避免使用已弃用的 BeanShell 或受限的 JavaScript。 2. **添加日志调试信息** 在脚本中加入 `log.info()` 或 `System.out.println()` 以确认脚本是否被执行。 3. **检查依赖库** 如果使用非 Groovy 语言(如 Python),确保相关脚本引擎的 JAR 文件(如 `jython-standalone.jar`)已放置在 `lib/ext` 目录下,并重启 JMeter。 4. **验证取样器执行路径** 确保 JSR223 PreProcessor 被附加到一个实际执行的取样器上,并且父级控制器未限制其执行。 5. **升级 JMeter 版本** JMeter 5.5 对 JSR223 的支持可能存在 Bug,建议升级到最新稳定版本(如 JMeter 5.6 或更高),以获得更好的兼容性和修复。 ### 示例代码(Groovy) ```groovy // 设置变量用于后续取样器 vars.put("username", "testuser") log.info("Username set to: " + vars.get("username")) ``` 上述脚本将用户名存储到 JMeter 变量中,并通过日志输出确认变量值。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值