1. 程式人生 > >Jmeter檢視結果樹Unicode編碼轉中文方法

Jmeter檢視結果樹Unicode編碼轉中文方法

本文為轉載微信公眾號文章,如作者發現後不願意,請聯絡我進行刪除 

jmeter工具的使用中,不管是測試介面還是除錯效能時,檢視結果樹必不可少,然而在檢視響應資料時,其中的中文經常以Unicode的編碼形式顯示,如圖1。這樣不能直接檢視到對應的中文是否為期望的結果,很不方便。


(樣例請求為http://ip.taobao.com/service/getIpInfo.php?ip=114.114.114.114

         我找到一個曲線救國的方法,供大家參考。得到結果,如圖2


(樣例請求為http://ip.taobao.com/service/getIpInfo.php?ip=114.114.114.114

操作步驟

第一步

在對應請求上新增後置處理器BeanShellPostProcessor,如圖3.



得到頁面,圖4


4

第二步

在後置處理器BeanShellPostProcessorscript中貼入Unicode的轉中文的編碼,如圖5


第三步

正常除錯並檢視結果樹,發現之前的Unicode的編碼的中文,已經轉碼完畢。

<End>

原理

         通過BeanShell內建變數prev,獲得響應資料,經過java程式編碼,把Unicode程式碼轉成中文,最後修改檢視結果樹中響應資料為轉換完畢的中文資料。

備註

1、在效能測試前,請把這個後置處理器刪除,不然會大量消耗本機的記憶體和

CPU,影響效能的結果

2、以上程式碼中的轉碼過程可以更改為更適合的程式碼,但要注意的是Jmeter3.0這個版本依舊對Integer.parseint()方法不能很好支援,執行會報錯。

3、關於獲取響應結果的變數值prev,具體API檢視:

程式碼如下:

//獲取響應程式碼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());

備註:原文通過公眾號發出,但是格式存在問題,我這裡的是格式化後的,直接複製貼上就可以使用的

原文連結:http://mp.weixin.qq.com/s?__biz=MjM5OTI2MTQ3OA==&mid=2652178311&idx=1&sn=9ac05bc08e688018b9df1681d17fdc43&chksm=bcdf83ce8ba80ad8177307c44f74d4acc5d5e247af69894986b2d3c72e1847cebee6117c4d4e&scene=0#rd