解决jmeter做接口测试时响应数据中文显示乱码或者Unicode码的问题

最近做jmeter接口测试ide时候,出现一个问题;请求成功之后返回的响应数据中文显示为Unicode码。如下图:

 

 最开始一位示乱码;修改jmeter的配置文件

打开jmeter下的目录:jmeter-5.3\bin 目录下的jmeter.properties

 

 sampleresult.default.encoding=utf-8

 

但是修改配置文件后发现接口响应数据还是乱码;后来对比postman,postman返回也是这种,知识postman有一个json格式转化的小工具,可以转化下面这种

 

 

jmeter也有查看json格式的响应数据;但是写响应断言的时候默认是text格式

 

 

解决办法:在对应请求后面添加后置处理器: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());

 

 

PS:

1、原理:通过BeanShell内置变量prev,获取响应数据,经过Java程序编码,把unicode转换成中文;最后查看结果数里面响应数据为转换之后的中文

2、在性能测试前,请把这个后置处理器删除,不然后消耗本机内存和CPU,会影响性能测试结果

posted @ 2021-06-03 09:51  风声~~  阅读(635)  评论(0编辑  收藏  举报