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

来源:互联网 发布:大狗狗影视下载软件 编辑:程序博客网 时间:2024/06/05 20:13
前几天学习jemeter做简单的接口测试时,出现了一个问题,问题是请求成功后返回的响应数据中文显示为了Unicode码
如下图:

最先开始还以为是乱码,所以百度出了一片博客http://blog.sina.com.cn/s/blog_6b0e39450102wlym.html
后来跟据博客的内容修改

但是根据这个修改之后发现仍然不行,后来对比postman看了下,postman返回的也是这种,只是postman有一个json格式化的小工具,可以转换成下面这种:

原因找到了,就看解决办法,所以就找到了http://www.cnblogs.com/wuyonghuan/p/7273917.html
文中说了在对应请求上添加后置处理器BeanShellPostProcessor添加完成后如下图

在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());
然后再次运行就OK了,如下图

但是上诉文中说了这也不是一劳永逸的办法,具体一劳永逸的办法待研究。


阅读全文
0 0