原方法:
BufferedReader reader = new BufferedReader(new InputStreamReader(
connection.getInputStream()));
String lines;
StringBuffer sb = new StringBuffer("");
while ((lines = reader.readLine()) != null) {
lines = new String(lines.getBytes(), "utf-8");
sb.append(lines);


在new InputStreamReader时默认用文件的编码格式(gbk)解析,若字符串中汉字个数为单数,此时最后一位汉字会因为少1个字节导致乱码;之后的 new String(lines.getBytes(), "utf-8")操作解析不出最后一位


解决方法:

BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream(),"utf-8"));
String lines;
StringBuffer sb = new StringBuffer("");
while ((lines = reader.readLine()) != null) {
lines = new String(lines.getBytes());
sb.append(lines);
}

读取字符流时直接使用utf-8,会直接接受并转化为bgk格式,不会导致乱码;

相关文章:

  • 2023-01-01
  • 2021-09-14
  • 2021-09-09
  • 2021-11-28
  • 2021-04-14
  • 2021-07-17
猜你喜欢
  • 2022-12-23
  • 2021-08-15
  • 2021-07-30
  • 2022-12-23
  • 2022-12-23
  • 2021-12-02
相关资源
相似解决方案