通过HttpServletRequest判断客户端浏览器类型是否为IE11

5 篇文章 0 订阅



今天测试同事对项目中的文件下个和Excel导出提了bug:

IE11浏览器下,文件名如果是中文,下载后的文件会出现乱码。而且下载的方式,是重新打开一个空白多余的浏览器标签。


跟了几次代码发现是通过request获取User-Agent判断客户端的浏览器类型时出了问题:

String agent = request.getHeader("User-Agent").toLowerCase();

客户端使用IE浏览器时,获取到的User-Agent信息是:

IE:Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko

与之前版本不同,没有了MSIE关键字来区分,而且与Firefox的很像:

Firefox:mozilla/5.0 (windows nt 10.0; wow64; rv:46.0) gecko/20100101 firefox/46.0

所以我用如下代码进行区分,并设置对应的相应头信息

		//识别IE浏览器
		if (agent != null && (agent.indexOf("msie") != -1 || 
				(agent.indexOf("rv") != -1 && agent.indexOf("firefox") == -1))) {
			name = URLEncoder.encode(name + ".xls", "UTF-8");
		} else {
			name = new String((name + ".xls").getBytes("UTF-8"), "ISO-8859-1");
		}
		
		res.reset();
		res.setContentType("application/octet-stream");
		res.setHeader("Content-disposition", "attachment; filename=" + name);


就酱~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值