Jmeter 處理Unicode編碼轉爲中文

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

真心不以爲返回報文加密能有多安全,別人將報文複製到安全

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

站點,一查不就清楚了麼,以下圖:ide

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

 

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

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

Step2: 可能會遇到的問題:spa

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

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

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()); 
相關文章
相關標籤/搜索