一.乱码解决办法
1.jmeter中修改http请求体中信息content encoding为UTF-8
2.修改bin文件夹中jmeter.properties文件中,搜索encoding,大约是第1030行,# The encoding to be used if none is provided (default ISO-8859-1) #sampleresult.default.encoding=(修改为UTF-8)
同时去除# 注释 需要重启
3.新增post processors中的BeanShell PostProcessor。将prev.setDataEncoding("ISO-8859-1")修改为prev.setDataEncoding("utf-8"),需要重启
二、unicode转utf8展示(推荐)
1.在刚才的第三点中 添加不同的代码(记住添加的是后置处理器 而不是前置处理器 看清楚是Post)

写入的代码为:(实际上就是java写的一个代码转换)
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());
三、读取dat文件(其实txt也可以 但是听人说必须dat,所以你们自己抉择吧)
提醒点:如果当你第一条数据总是多了一个问号,检查文件编码或者csv中设置编码,本地文件设置ansi,csv设置utf-8问题解决



本文介绍了如何解决JMeter中Unicode编码导致的乱码问题,包括修改HTTP请求内容编码、调整配置文件以及使用BeanShell PostProcessor进行转换。此外,还讲述了如何读取DAT文件,提到了文件编码的注意事项。

被折叠的 条评论
为什么被折叠?



