jmeter中文乱码及Unicode转中文

Posted t-ae

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jmeter中文乱码及Unicode转中文相关的知识,希望对你有一定的参考价值。

在测试的过程中传入中文测试,乱码问题

1、get请求传入中文参数address:中国云南省

技术分享图片

技术分享图片

 

request请求中已经正确显示参数(可能跟我之前配置过有关系),如果没有正确显示,在http取样器后面新建一个BeanShell Sampler(并列关系)

scrip里编辑代码:prev.setDataEncoding("utf-8");再次运行就可以,不用重启jmeter

技术分享图片

再查看response响应信息 address返回值是Unicode编码的

技术分享图片

在http请求中添加后置处理器BeanShell PostProcessor,scrip中编辑代码:

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=‘	‘;
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());

 再次执行,查看响应结果,address显示乱码

技术分享图片

 打开jmeter.properties(jmeter的bin目录下)把默认的编码改成utf-8,并把注释取消保存,重启jmeter

技术分享图片

再次运行,响应信息显示正确

技术分享图片

2、Post请求传递中文参数

技术分享图片

技术分享图片

响应乱码,修改post请求,Content encoding设置成utf-8

技术分享图片

再次运行:参数显示Unicode编码,

技术分享图片

post请求再次建立后置处理器BeanShell PostProcessor内容与上面一致

再次运行成功

技术分享图片

 

 

 

 

 

 

 

 

 


以上是关于jmeter中文乱码及Unicode转中文的主要内容,如果未能解决你的问题,请参考以下文章

jmeter响应信息unicode 编码转成中文

一Jmeter总结

CentOS7的中文乱码原因及编码设置

python 如何将乱码转成汉字

JMeter中文乱码的解决

JMETER响应数据返回json乱码