解决IE和FF下载中文名称的文件文件名乱码的问题.
下载前判断浏览器类型
采用不同的文件名编码方式
网上通用的做法是使用 javamail里的一个工具类
后来经过试验,我们可以使用更轻量级的jar包
commons-codec.jar
apache的一个小项目.
下面是实现文件名编码的方法
?
- //?其中?Base64?类来自?org.apache.commons.codec?组件?一个40多k的jar?要比javamail里的那个简洁很多??public?static?String?encodeFileName(HttpServletRequest?request,?String?fileName)?throws?UnsupportedEncodingException?{??????String?agent?=?request.getHeader("USER-AGENT");??????if?(null?!=?agent?&&?-1?!=?agent.indexOf("MSIE"))?{??????????return?URLEncoder.encode(fileName,?"UTF8");??????}else?if?(null?!=?agent?&&?-1?!=?agent.indexOf("Mozilla"))?{??????????return?"=?UTF-8?B?"+(new?String(Base64.encodeBase64(fileName.getBytes("UTF-8"))))+"?=";??????}?else?{??????????return?fileName;??????}??}??