Jmeter响应的数据是unicode编码格式,怎么转成中文字符显示
2017-08-30 10:34
495 查看
本文为转载微信公众号文章,如作者发现后不愿意,请联系我进行删除
在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
在后置处理器BeanShellPostProcessor的script中贴入Unicode的转中文的编码,如图5。
正常调试并查看结果树,发现之前的Unicode的编码的中文,已经转码完毕。
<End>
通过BeanShell内置变量prev,获得响应数据,经过Java程序编码,把Unicode代码转成中文,最后修改查看结果树中响应数据为转换完毕的中文数据。
1、 在性能测试前,请把这个后置处理器删除,不然会大量消耗本机的内存和CPU,影响性能的结果
2、 以上代码中的转码过程可以更改为更适合的代码,但要注意的是Jmeter3.0这个版本依旧对Integer.parseint()方法不能很好支持,运行会报错。
3、 关于获取响应结果的变量值prev,具体API查看:
http://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html
代码如下:
//获取响应代码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
在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
第二步
在后置处理器BeanShellPostProcessor的script中贴入Unicode的转中文的编码,如图5。
第三步
正常调试并查看结果树,发现之前的Unicode的编码的中文,已经转码完毕。<End>
原理
通过BeanShell内置变量prev,获得响应数据,经过Java程序编码,把Unicode代码转成中文,最后修改查看结果树中响应数据为转换完毕的中文数据。
备注
1、 在性能测试前,请把这个后置处理器删除,不然会大量消耗本机的内存和CPU,影响性能的结果2、 以上代码中的转码过程可以更改为更适合的代码,但要注意的是Jmeter3.0这个版本依旧对Integer.parseint()方法不能很好支持,运行会报错。
3、 关于获取响应结果的变量值prev,具体API查看:
http://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html
代码如下:
//获取响应代码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
相关文章推荐
- jmeter-察看结果树-响应数据中的中文显示乱码
- 转 JMeter之修改Sampler响应数据的编码格式
- Jmeter查看结果树响应结果unicode转成中文显示
- jmeter-察看结果树-响应数据,中文显示乱码问题处理
- jmeter-察看结果树-响应数据中的中文显示乱码
- Java使用百度API 返回JSON数据为unicode编码,怎么转化为中文?
- Jmeter查看结果树响应结果unicode转成中文显示
- Foundation+Log.m,让网络请求回来的中文被unicode编码的数据汉字显示
- jmeter-察看结果树-响应数据,中文显示乱码
- jmeter-察看结果树-响应数据,中文显示乱码问题处理
- jmeter-察看结果树-响应数据,中文显示乱码问题处理
- JMeter之修改Sampler响应数据的编码格式
- jmeter-察看结果树-响应数据,中文显示乱码问题处理
- http 请求数据返回 json 中中文字符为 unicode 编码转汉字转码
- 该文件包含不能在当前代码页(936)中表示的字符。请将该文件保存为 Unicode 格式以防止数据丢失
- 查看中文字符的unicode编码
- txt中,ANSI 的编码格式为什么可以显示中文?
- 编码为GB2312网站让AJAX接收的数据显示支持中文
- Unicode中关于中文和其他特殊字符的编码范围
- source-insight中文:utf-8编码的中文字符在source in sight如何正常显示