Jmeter运行结果unicode编码乱码问题

一、web页面乱码

  比如访问百度返回页面显示乱码,如下会有问号

  如果想让他显示中文可以按以下操作:

1、打开jmter配置文件

bin/jmeter.properties

2、修改配置文件,查找“sampleresult.default.encoding”将其改为utf8,注意要去掉“#”号

sampleresult.default.encoding=utf-8 

3、重启 jmeter

4、再次运行脚本此时中文显示正常

二、返回json乱码

  如果咱们请求一个接口返回json数据,在响应数据中为 unicode 编码数据,对于查看和添加检查点有些费解。

  如果想让他显示中文可以按以下操作:

1、添加一个"Bean shell PostProcessor"

 2、 在“Script”中添加如下代码

        String s=new String(prev.getResponseData(),"UTF-8");
        char aChar;
        int len= s.length();
        StringBuffer outBuffer=new StringBuffer(len);
        for(int x =0; x <len;){
            aChar= s.charAt(x++);
            if(aChar=='\\'){
                aChar= s.charAt(x++);
                if(aChar=='u'){
                    int value =0;
                    for(int i=0;i<4;i++){
                        aChar= s.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、重新运行脚本,中文就显示出来了

注:

  1、之后你的断言中就可以使用中文断言;

  2、但如果想用此脚本做压力测试需要把"Bean shell PostProcessor"禁用掉;

  3、如果使用中文断言当禁用后会报错,所以如果需要性能测试不要使用中文断言。

 

  

 参考资料:

  http://www.cnblogs.com/rslai/p/7922548.html

posted @ 2017-11-29 20:27  rslai  阅读(986)  评论(0编辑  收藏  举报