共计 743 个字符,预计需要花费 2 分钟才能阅读完成。
jmter默认是无法发送syslog的,不过我们可以通过安装UDP request这一插件来实现,安装步骤参考JMeter发送UDP
但经实际测试这种方式含有中文的数据时,接收端会中文乱码,如下图例子所示,数字和英文字母都正常,但中文字符”我的”到了接收端变成了”??”
data:image/s3,"s3://crabby-images/ae36c/ae36cfe529ba4926d4fd19e8356582767b371180" alt="Jmeter发送syslog,解决中文乱码 Jmeter发送syslog,解决中文乱码"
data:image/s3,"s3://crabby-images/79e0e/79e0e550e695b808f5de59c92a129c7486d557ae" alt="Jmeter发送syslog,解决中文乱码 Jmeter发送syslog,解决中文乱码"
经调研,我们可以利用HexStringUDPDecoder+BeanShell PreProcessor来解决
首先将要发送的内容统一定义
data:image/s3,"s3://crabby-images/41995/41995044a4946ee3ae8117048bbefebdbd2bc097" alt="Jmeter发送syslog,解决中文乱码 Jmeter发送syslog,解决中文乱码"
添加一个BeanShell PreProcessor,用于将参数转为16进制
data:image/s3,"s3://crabby-images/5311d/5311d53d74387cc4527f2df05c34bc4b6844abd8" alt="Jmeter发送syslog,解决中文乱码 Jmeter发送syslog,解决中文乱码"
具体代码为:
String input = vars.get("paramIn_test");
log.info("input:"+input);
char[] HEX_CHARS = "0123456789ABCDEF".toCharArray();
byte[] buf = input.getBytes("UTF-8");
char[] chars = new char[2 * buf.length];
for (int i = 0; i < buf.length; ++i)
{
chars[2 * i] = HEX_CHARS[(buf[i] & 0xF0) >>> 4];
chars[2 * i + 1] = HEX_CHARS[buf[i] & 0x0F];
}
String output = new String(chars);
log.info("output:"+output);
vars.put("output",output);
最后,在发送时做以下两处改动,将Data Encode/Decode class改为kg.apc.jmeter.samplers.HexStringUDPDecoder,将Request Data直接使用我们上一步得到的output
data:image/s3,"s3://crabby-images/81544/81544b924b31db3c27a06eebfbd545f243d3e187" alt="Jmeter发送syslog,解决中文乱码 Jmeter发送syslog,解决中文乱码"
再次发送,可以看到我们乱码问题已经解决
data:image/s3,"s3://crabby-images/3bda1/3bda1c1e1ce84fd33adb45fe87d501e3517878ac" alt="Jmeter发送syslog,解决中文乱码 Jmeter发送syslog,解决中文乱码"
正文完