获取读取到的字节流中的文件编码防止乱码

乱码的根本原因是输入流和输出流的编码方式不一致造成的,这个可以依据输入流的编码来动态的使用改编码输出
1.pom.xml加入:



  com.googlecode.juniversalchardet
  juniversalchardet
  1.0.3

 

2.  工具类

  class GetByteEncode {
    String getEncoding(byte[] bytes) {
      String deafultCode = "UTF-8";
      UniversalDetector detector = new UniversalDetector(null);
      detector.handleData(bytes, 0, bytes.length);
      detector.dataEnd();
      String encoding = detector.getDetectedCharset();
      detector.reset();
      if (encoding == null) {
        encoding = deafultCode;
      }
      return encoding;
    }
  }

3.使用:

 String filenameIso = new String(data.getFileName().getBytes("UTF-8"), "iso-8859-1");
        /* 设置文件名 */
        response.addHeader("Content-Disposition", "fileName=\"" + filenameIso + "\"");
        os = response.getOutputStream();
        byte[] b = fileInfo.getData().getFileByte();
        String encoding = new GetByteEncode().getEncoding(b); //编码判断 --动态
        response.setHeader("Content-type", "text/html;charset=" + encoding);
        String a = new String(fileInfo.getData().getFileByte(), encoding);
        os.write(a.getBytes(encoding));

 

 

 

你可能感兴趣的:(java,乱码,java)