Jmeter | 响应数据中文乱码

解决 jmeter 返回数据的中文乱码问题

Posted by Haauleon on July 21, 2022

一、背景

访问百度首页时,接口返回的是乱码(是真正的乱码,根本看不出来是什么字母)



二、解决

方法1、修改配置文件

(1)进入 jmeter 安装目录下的 bin/ 目录,找到文件 jmeter.properties,然后点击编辑。


(2)搜索找到 sampleresult.default.encoding ,然后将编码改成 UTF-8


(3)保存文件,并重启 Jmeter 即可解决。


若解决不了就用方法 2


方法2、信息头管理器

(1)添加 HTTP信息头管理器
  HTTP信息头管理器 在 HTTP 请求之前添加。在线程组中添加和在测试计划中添加的区别在于作用域的问题,一个作用于当前线程组的所有 HTTP 请求,一个作用于整个测试计划中的 HTTP 请求。


(2)增加 Content-Type:application/json;charset=UTF-8


(3)无需重启,直接重新运行,然后查看结果树即可解决。


若解决不了就用方法 3


方法3、后置处理器

(1)添加 后置处理器 > BeanShell PostProcessor
  后置处理器 在 HTTP 请求之后添加。在线程组中添加和在测试计划中添加的区别在于作用域的问题,一个作用于当前线程组的所有 HTTP 请求,一个作用于整个测试计划中的 HTTP 请求。


(2)增加脚本 prev.setDataEncoding("utf-8");


(3)无需重启,直接重新运行,然后查看结果树即可解决。


若解决不了就用方法 4


方法4、后置处理器

(1)添加 后置处理器 > BeanShell PostProcessor
  后置处理器 在 HTTP 请求之后添加。在线程组中添加和在测试计划中添加的区别在于作用域的问题,一个作用于当前线程组的所有 HTTP 请求,一个作用于整个测试计划中的 HTTP 请求。


(2)增加以下脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
//获取响应代码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());


(3)无需重启,直接重新运行,然后查看结果树即可解决。