IE11浏览器下导出Excel没有文件扩展名

在IE11浏览器中导出Excel文件时遇到一个问题,即生成的文件缺少文件扩展名。为了解决这个问题,需要编写一个工具类进行综合判断和处理,确保导出的文件带有正确的.xlsx或.xls扩展名。
使用poi,做传统的excel导出,然后想在浏览器中,让用户选择另存为,保存用户下载的xls文件,这个时候,可能的是在ie下出现乱码(ie,9,10,11),但在firefox,chrome下没乱码, 

因此必须综合判断,编写一个工具类: 

response.setHeader("Cache-Control", "private");  
		response.setHeader("Pragma", "private"); 
		response.setContentType("application/vnd.ms-excel;charset=UTF-8");
		response.setHeader("Content-Type", "application/force-download"); 
		filename = ExcelNameEncode.encodeFilename(filename, request);// 处理中文文件名
		response.setHeader("Content-disposition", "attachment;filename="
				+ filename);
public static String encodeFilename(String filename,
			HttpServletRequest request) {
		/**
		 * 获取客户端浏览器和操作系统信息 在IE浏览器中得到的是:User-Agent=Mozilla/4.0 (compatible; MSIE
		 * 6.0; Windows NT 5.1; SV1; Maxthon; Alexa Toolbar)
		 * 在Firefox中得到的是:User-Agent=Mozilla/5.0 (Windows; U; Windows NT 5.1;
		 * zh-CN; rv:1.7.10) Gecko/20050717 Firefox/1.0.6
		 */
		String agent = request.getHeader("USER-AGENT");
		try {
			if(agent != null){
				if (agent.indexOf("MSIE") != -1 || agent.indexOf("Trident") != -1) {
					return URLEncoder.encode(filename, "UTF-8");
				} else if (agent.indexOf("Mozilla") != -1) {
					return MimeUtility.encodeText(filename, "UTF-8", "B");
				}
			}
			return filename;
		} catch (Exception ex) {
			return filename;
		}
	}

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值