默认情况下,Jmeter 在请求接口的时候,响应结果如果存在中的话默认会按照 uncode 处理,这样的话对于测试来说是非常不方便的所以,这里就分享一个由 uncode 编码转换为 utf-8 的方式;当然啦!我这个也是抄的,一方面是方便我自己查阅;一方面也是为了你们误入歧途(找不到称心的解决方案);
一、修改文件
找到 Jmeter 安装目录中 bin 目录下的 jmeter.properties 文件,使用 sublime 等软件打开;
-
搜索关键字,
default.encoding
找到如下代码;# The encoding to be used if none is provided (default ISO-8859-1) #sampleresult.default.encoding=ISO-8859-1
-
在后面一行追加如下代码,下面粘贴已经修改好的代码;
# The encoding to be used if none is provided (default ISO-8859-1) #sampleresult.default.encoding=ISO-8859-1 sampleresult.default.encoding=utf-8
做完第一步操作后,一定要重启一下 Jmeter !!!
二、添加组件
-
在指定线程组下添加 后置处理器 -> BeanShell PostProcessor ,然后在 script 处粘贴一下代码;
//获取响应代码Unicode编码的 String s2 = new String(prev.getResponseData(), "UTF-8"); //---------------一下步骤为转码过程--------------- char aChar; int len = s2.length(); StringBuffer outBuffer = new StringBuffer(len); for (int x = 0; x < len;) { aChar = s2.charAt(x++); if (aChar == '\\') { aChar = s2.charAt(x++); if (aChar == 'u') { int value = 0; for (int i = 0; i < 4; i++) { aChar = s2.charAt(x++); switch (aChar) { case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9': value = (value << 4) + aChar - '0'; break; case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': value = (value << 4) + 10 + aChar - 'a'; break; case 'A': case 'B': case 'C': case 'D': case 'E': case 'F': value = (value << 4) + 10 + aChar - 'A'; break; default: throw new IllegalArgumentException("Malformed \\uxxxx encoding."); } } outBuffer.append((char) value); } else { if (aChar == 't') aChar = '\t'; else if (aChar == 'r') aChar = '\r'; else if (aChar == 'n') aChar = '\n'; else if (aChar == 'f') aChar = '\f'; outBuffer.append(aChar); } } else outBuffer.append(aChar); } //-----------------以上内容为转码过程--------------------------- //将转成中文的响应结果在查看结果树中显示 prev.setResponseData(outBuffer.toString());
以上操作之后,就可以使用 Jmeter 安静的测试了,但是在正式测试的时候,切记不要使用这种方式,会很消耗性能,影响性能测试的稳定性,可在调试阶段,使用此方法;下面附操作成功图。