jmeter如何解决unicode转utf-8(并且读取dat文件数据)

一.乱码解决办法

1.jmeter中修改http请求体中信息content encoding为UTF-8 
2.修改bin文件夹中jmeter.properties文件中,搜索encoding,大约是第1030行,# The encoding to be used if none is provided (default ISO-8859-1) #sampleresult.default.encoding=(修改为UTF-8)
) 同时去除# 需要重启
3.新增post processors中的BeanShell PostProcessor。将prev.setDataEncoding("ISO-8859-1")修改为prev.setDataEncoding("utf-8"),需要重启

二、unicode转utf8展示(推荐)

1.在刚才的第三点中 添加不同的代码(记住添加的是后置处理器 而不是前置处理器  看清楚是Post)


写入的代码为:(实际上就是java写的一个代码转换)

 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());



三、读取dat文件(其实txt也可以 但是听人说必须dat,所以你们自己抉择吧)

提醒点:如果当你第一条数据总是多了一个问号,检查文件编码或者csv中设置编码,本地文件设置ansi,csv设置utf-8问题解决



猜你喜欢

转载自blog.csdn.net/tester_xjp/article/details/80854814