zl程序教程

您现在的位置是:首页 >  其它

当前栏目

jmeter乱码问题解决

解决 乱码 JMeter 问题
2023-09-27 14:25:19 时间
工作中常见的jmeter调用接口时遇到乱码有3种情况
1.访问httpbin.org时,入参传中文,响应中包含入参的数据时,中文显示为unicode
 
2.访问百度首页时,接口返回的是乱码(是真正的乱码,根本看不出来是什么字母)
 
3.请求响应中的出参应显示中文,现在是?
 

解决方法:
此时,我们可以先尝试将jmeter配置文件jmeter.properties 修改其中一行(在安装jmeter时的目录里)
sampleresult.default.encoding=UTF-8
一定记得改完配置文件后重启jemeter

重启成功后再次运行,这次访问百度的响应中乱码已经没了,正常显示中文
 

 

但是httpbin.org中的响应还是unicode,没有变化。
那只能继续想其他方法:
1.在线程组右击增加HTTP信息头管理器
增加Content-Type:application/json;charset=UTF-8
重新执行后,在 【查看结果树】 中查看响应,没有作用

2.在线程组中右击点击【添加】--后置处理器--BeanShell PostProcessor
在脚本里写上
prev.setDataEncoding("utf-8");
重新执行,在 【查看结果树】 中查看响应,没有作用

3.继续网上找解决方案,看到在后置处理器中添加另一种脚本
重新执行,在 【查看结果树】 中查看响应,终于显示成中文了

 

脚本如下:
//获取响应代码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());

 

4.HTTP请求填写内容编码
出现第三种情况,可以再去检查下HTTP请求中的内容编码,这里没有填写任何编码,现在填写上utf-8后,再次请求后,中文显示成功

 
 

作者:爱晴空0916
链接:https://www.jianshu.com/p/dfd68e52cb6f
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。