多种Jmeter中文乱码问题处理方法

发表于:2022-11-25 09:52

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:Hapen_Lu    来源:CSDN

  【背景】
  使用jmeter的小伙伴多多少少都会有遇见中文乱码的问题,主要有请求体中文乱码、响应报文的中文乱码以及文件上传的中文乱码。
  【原因】
  jmeter源码里默认的编码是ISO-8859-1。
  【处理方法】
  通过设置和修改源码两种主要方式来解决中文乱码问题。
  处理方式一:
  在HTTP请求控件指向UTF-8,解决请求中文乱码,如下图:
  处理方式二:
  在jmeter/bin路径下的jmeter.properties,第1098行,将默认的encoding=ISO-8859-1改为UTF-8,解决返回结果的中文乱码,如下:
  # The encoding to be used if none is provided (default ISO-8859-1)
  #sampleresult.default.encoding=ISO-8859-1
  sampleresult.default.encoding=UTF-8
  处理方式三:
  在源码中进行强制修改,将默认的encoding改为UTF-8,解决所有的中文乱码问题。
  1、在RequestViewHTTP类中将CHARSET_DECODE赋值为UTF-8,RequestViewHTTP在“\src\protocol\http\src\main\java\org\apache\jmeter\protocol\http\visualizers”这个路径下,也可以通过Ctrl+Shift+F(Commad+Shift+F)直接搜索RequestViewHTTP。如下图 :
   2、修改SampleResult类中的 DEFAULT_HTTP_ENCODING的值,将默认的 ISO_8859_1改为UTF-8。SampleResult类在Samples下面,“\src\core\src\main\java\org\apache\jmeter\samplers”,如下图:
  3、通过修改 HTTPHC4Impl 类中的setupHttpEntityEnclosingRequestData方法,HTTPHC4Imp类在路径“\src\protocol\http\src\main\java\org\apache\jmeter\protocol\http\sampler”当为Multipar类型的时候设置Charset的值,修改源码如下:
  protected String setupHttpEntityEnclosingRequestData(HttpEntityEnclosingRequestBase entityEnclosingRequest)  throws IOException {
          // Buffer to hold the post body, except file content
          StringBuilder postedBody = new StringBuilder(1000);
          HTTPFileArg[] files = getHTTPFiles();
   
          final String contentEncoding = getContentEncodingOrNull();
          final boolean haveContentEncoding = contentEncoding != null;
   
          // Check if we should do a multipart/form-data or an
          // application/x-www-form-urlencoded post request
          if(getUseMultipart()) {
              ......
              // Write the request to our own stream
              MultipartEntityBuilder multipartEntityBuilder = MultipartEntityBuilder.create();
              if(getDoBrowserCompatibleMultipart()) {
                  multipartEntityBuilder.setLaxMode();
                  // 解决上传文件的中文乱码
                  if (haveContentEncoding){
                      multipartEntityBuilder.setCharset(Charset.forName(contentEncoding));
                  }
              } else {
                  multipartEntityBuilder.setStrictMode();
              }
  ......
  }
  增加了下面的代码对文件编码进行判断和赋值:
  if (haveContentEncoding){
      multipartEntityBuilder.setCharset(Charset.forName(contentEncoding));
  }
  【总结】
  通过以上两种方式可以解决jmeter的中文乱码问题。
  本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号