Apache JMeter应用中对于中文乱码的主要解决方法

来源:互联网 发布:vivo深圳研发待遇知乎 编辑:程序博客网 时间:2024/05/16 08:29

PS:本人使用文章中的方法还是解决不了,最后尝试用notepad打开参数化文件,菜单栏【编码】选择【以utf-8无rom格式编码】(如下图),保存后再执行就OK了。





================================================================================================================================

以下是转载文章正文


SampleResult中的中文乱码解决方法

对jmeter.properties进行设置,从jmeter.properties配置文件中可以找到如下行:

# The encoding to be used if none is provided (default ISO-8859-1)#sampleresult.default.encoding=ISO-8859-1
  • 1
  • 2

可以将此行的注释去掉,可以看到默认为ISO-8859-1编码,我们只需要将编码根据中文编码需求更改为utf-8、gb18030等,从而实现正确处理中文,如:

# The encoding to be used if none is provided (default ISO-8859-1)sampleresult.default.encoding=utf-8
  • 1
  • 2

Sampler中文乱码解决方法

比如,在实际应用HTTPSampler进行测试的过程中,我们会碰到如下情况: 
这里写图片描述

中文乱码问题,这一直是困扰中文环境下性能测试人员的一个难于彻底解决的问题,但对于JMeter这样的开源测试工具来说,这就不是什么难以解决的问题了。我们知道在现有的JMeter版本中HTTPSampler主要可以通过选择Java、HttpClient3.1和HttpClient4来设置最终模拟HTTP协议与Web服务器交互的真正实现方法。我这里选取Java实现方法作为参考,从JMeter源码包org.apache.jmeter.protocol.http.sampler中查看源代文件PostWriter.java,发现这样一行:

public static final String ENCODING = "ISO-8859-1";
  • 1

以及以下代码:

String contentEncoding = sampler.getContentEncoding();if(contentEncoding == null || contentEncoding.length() == 0) {    contentEncoding = ENCODING;}
  • 1
  • 2
  • 3
  • 4

这里写图片描述

可以看出如果没有设置Content encoding项,JMeter同样是默认为ISO-8859-1编码,一种一劳永逸的方法(这里只是一个针对HTTPSampler的例子,但可以根据此思路扩展到所有需要中文字符编码的Sampler中),我们只需要将默认编码根据中文编码需求更改为utf-8、gb18030等,就可以实现POST正确的中文到Web服务器了。参考如下修改:

public static final String ENCODING = "utf-8";
  • 1

之后将新编译的PostWriter.class替换D:\JMeter\apache-jmeter-2.13\apache-jmeter-2.13\lib\ext下的这里写图片描述中的原class文件即可,在应用HTTPSampler记住选择: 
这里写图片描述

为实现方法就可以实现我们所设置的默认utf-8中文字符集编码了。 
当然最普遍的方法就是设置Content encoding项完成中文编码,如下图所示: 
这里写图片描述

此上两种方法均可以达到目的: 
这里写图片描述

HTTP协议录制中文问题

在进行HTTP协议测试过程中,我们往往会借助JMeter为我们提供的HTTP代理服务器进行测试脚本的录制,一个典型的录制计划如如下图: 
这里写图片描述

通过HTTP代理服务器生成HTTPSampler,而往往会遇到这样的录制结果: 
这里写图片描述

由于在浏览器中的showName项输入了中文,因此,在录制所生成的HTTPSampler的POST表单中出现了中文乱码情况。 
我们可以在org.apache.jmeter.protocol.http.proxy包中的DefaultSamplerCreator.java源文件中发现如下代码:

if (!StringUtils.isEmpty(contentEncoding)) {                postData = new String(request.getRawPostData(), contentEncoding);            } else {                // Use default encoding                postData = new String(request.getRawPostData(), PostWriter.ENCODING);            }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

会发现造成中文乱码的原因是无法从Content encoding中读取信息,而使用了默认的ISO-8859-1编码,因此,我们只需要指明我们中文编码即可解决上述问题,最简单的方案是注释掉上面那段代码,设置一个全局的默认中文编码,如下方法:

postData = new String(request.getRawPostData(), "utf-8");
  • 1

之后将新编译的DefaultSamplerCreator.class替换D:\JMeter\apache-jmeter-2.13\apache-jmeter-2.13\lib\ext下的这里写图片描述中的原class文件即可。 
再次录制,可以看到能够正常显示中文了: 
这里写图片描述


0 0
原创粉丝点击