问题描述:
最近在使用Springboot实现文件下载功能时,由于原始文件只能是utf-8编码,无法在前期进行转码,所以下载下来的文件都是utf-8的编码;文件又是CSV文件,下游使用习惯一般是直接用excel打开,但是一直会出现中文乱码的情况。
原因分析:
通过网上查询的结果是,Excel打开的CSV文件默认是ANSI编码,如果CSV文件的编码方式为UTF-8、Unicode等编码可能就会出现文件乱码的情况。
解决方案:
针对上述原因,解决方法有两种,一种是从文件源头解决,把文件转为GBK的即可,但这种方法不可用,所以采用了另外一种方法,那就是告诉excel:这是一个utf-8编码的文件,你用utf-8打开。
具体方法就是在文件头部添加BOM标记,具体代码为:
outputStream.write(new byte []{( byte ) 0xEF ,( byte ) 0xBB ,( byte ) 0xBF });
BOM中文名是字节顺序标记(英语:byte-order mark,BOM)是位于码点U+FEFF
的Unicode字符的名称。常被用来当做标示文件是以UTF-8、UTF-16或UTF-32编码的标记。Windows就是使用BOM来标记文本文件的编码方式的。
UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明编码方式。当文本程序读取到以EF BB BF
开头的字节流时,就知道这是UTF-8编码了。同理,若没有BOM的场合,可能无法正确识别编码,工具会使用默认的编码,编码不匹配则会导致乱码。