• jmter响应中文乱码解决方法----通过BeanShell 后置处理程序


    jmeter响应数据中,中文数据乱码

        

    解决方法----通过后置处理器BeanShell PostProcessor 

       线程组右键----添加----后置处理器----BeanShell 后置处理程序

          

         在 BeanShell 后置处理程序 的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='	';
                        else if(aChar=='r')
                        aChar='
    ';
                        else if(aChar=='n')
                        aChar='
    ';
                        else if(aChar=='f')
                        aChar='f';
                        outBuffer.append(aChar);}}else
                    outBuffer.append(aChar);}
    //-----------------以上内容为转码过程---------------------------
    //将转成中文的响应结果在查看结果树中显示
            prev.setResponseData(outBuffer.toString());

          

        重新运行。响应中,中文正常显示。

       

  • 相关阅读:
    elasticsearch之建议器Suggester
    elasticsearch,kibana之相关配置
    elasticsearch之分析过程
    elasticsearch之mappings
    elasticsearch for Mac OS
    项目精讲
    博客园项目开发流程
    Django之auth模块
    DJango中间件
    DJango之模板层
  • 原文地址:https://www.cnblogs.com/taiyangfeng/p/12354210.html
Copyright © 2020-2023  润新知