做附件下载时,一般如此实现:
out = response.getOutputStream();
response.reset();
response.setHeader("Content-Disposition", "attachment;filename=" + browName);
response.setContentType(contentType);
byte[] fileByte = new byte[1024];
while (fileInputStream.read(fileByte) > 0){
out.write(fileByte, 0, fileByte.length);
}
out.flush();
out.close();
out = null;
如果文件名是中文,下载显示乱码,一般使用browName=java.net.URLEncoder.encode(realFileName, "UTF-8")编码处理,此方式在FF下显示乱码,在IE下如果文件名长则不能直接打开。
于是想到了RFC2047编码,但IE又下不支持RFC2047,但可以变通,判断客户端类型解决;
问题又出现:使用RFC2047编码,如果文件名长,则出现换行(根据RFC822规定,每76个字符,还需要加上一个回车换行。),所以还要处理换行符。
综合解决方式是:
String browName = "=?UTF-8?B?" + new String(Base64.encode(realFileName.getBytes("UTF-8"))) + "?=";
//处理换行符(如果存在)
StringReader sr = new StringReader(browName);
BufferedReader br = new BufferedReader(sr);
String line = null;
String temp = "";
while((line=br.readLine())!=null){
temp += line;
}
browName = temp;
//如果是IE
String clientInfo = request.getHeader("User-agent");
if(clientInfo != null && clientInfo.indexOf("MSIE") > 0 ){//IE采用URLEncoder方式处理
if(clientInfo.indexOf("MSIE 6") > 0 || clientInfo.indexOf("MSIE 5") > 0){//IE6,用GBK,此处实现由局限性
browName = new String(realFileName.getBytes("GBK"),"ISO-8859-1");
}else{//ie7+用URLEncoder方式
browName = java.net.URLEncoder.encode(realFileName, "UTF-8");
}
}
response.setHeader("Content-Disposition",
"attachment;filename=" + browName);
解决!
。。。。
此实现方式 如果在IE5、6下查看非中文、非英文的附件名还是会出现乱码,涉及国际化时应注意,
但基本能满足国人处理中文附件名的问题。
在IE5、6下想不出解决方式了,谁有解决方案请跟贴!