今天写文件下载时,发现以前忽略的问题,写个小记录
我们一般使用中文操作系统,所以要求的 文件名编码最好是utf-8,国际化一点
但是,似乎实际上不是这样
1. String fileName=new String(URLEncoder.encode(fileName,"utf-8"));
getResponse().addHeader("Content-Disposition","attachment;filename="+fileName);
或者new String(fileName.getBytes(),"utf-8")
//都是乱码资审文件模板
2.使用gbk呢,不管是URLEncoder.encode还是fileName.getBytes()都也是乱码 //如 ____.txt
3. 使用ISO8859-1呢
String fileName=new String(URLEncoder.encode(fileName,"ISO8859-1"));
//乱码 ??????.txt
只有在
new String(fileName.getBytes(),"ISO8859-1"); //正确,不发生乱码
我长出一口气,为啥子呢,查了查资料,只知道encodeURI 与encodeURIComponent类似,其他还有待学习
总之一句话,Java下载文件时文件名用new String(fileName.getBytes(),"ISO8859-1"); 转码就对了。
转载请注明原文地址: https://ju.6miu.com/read-962873.html