Jmeter 處理Unicode編碼轉為中文


對於接口中返回報文,有的接口返回信息是Unicode編碼,寫斷言的時候,要么就Response Assertion就寫成Unicode編碼的斷言,如下圖:

真心不覺得返回報文加密能有多安全,別人將報文復制到

http://tool.chinaz.com/tools/unicode.aspx

站點,一查不就清楚了么,如下圖:

秉承着學習的態度,我還是試了試Jmeter能否對響應報文中Unicode編碼轉中文。 

 

思想1: 用BeanShell PostProcessor將響應報文中Unicode編碼直接轉中文。

操作: Step1: 將請求中添加BeanShell后置處理器,張貼下面代碼,保存。運行,返回信息如下。

Step2: 可能會遇到的問題:

1,中文顯示????亂碼怎么辦? 修改jmeter.properties中默認編碼格式為UTF-8,保存,重啟Jmeter生效。

# The encoding to be used if none is provided (default ISO-8859-1)
sampleresult.default.encoding=UTF-8

2,沒有轉碼為中文怎么辦?  查看代碼,看看Java中運行能否成功。

 

代碼如下:

String s=new String(prev.getResponseData(),"UTF-8");
        char aChar;
        int len= s.length();
        StringBuffer outBuffer=new StringBuffer(len);
        for(int x =0; x <len;){
            aChar= s.charAt(x++);
            if(aChar=='\\'){
                aChar= s.charAt(x++);
                if(aChar=='u'){
                    int value =0;
                    for(int i=0;i<4;i++){
                        aChar= s.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());

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM