首页 > 其他 > 详细

Jmeter 响应 uncode 编码转为中文

时间:2020-02-24 20:46:32      阅读:61      评论:0      收藏:0      [点我收藏+]

默认情况下,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 安静的测试了,但是在正式测试的时候,切记不要使用这种方式,会很消耗性能,影响性能测试的稳定性,可在调试阶段,使用此方法;下面附操作成功图。

技术分享图片

Jmeter 响应 uncode 编码转为中文

原文:https://www.cnblogs.com/article-record/p/12358217.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!