文件名乱码问题和浏览器是有关系的,ie和火狐对文件名的解释不一样。
ie中避免乱码:
URLEncoder.encode(srcFileName,"utf-8");
srcFileName = new String(srcFileName.getByte("utf-8"), "iso-8859-1");
response.setCharacterEncoding("utf-8");
response.setHeader("Content-disposition", "attachment;filename=" + srcFileName);
火狐中避免乱码:
srcFileName = new String(srcFileName.getByte("utf-8"), "iso-8859-1");
response.setCharacterEncoding("utf-8");
response.setHeader("Content-disposition", "attachment;filename=" + srcFileName);
如何用java判断浏览器类型?
如题
------解决方案--------------------
request.getHeader("user-agent");
------解决方案--------------------
**
* 判断浏览器类型是否是IE,是则返回true,不是返回false
* ServletActionContext是struts2上下文对象
* @return boolean
*/
public static boolean isIE(){
return ServletActionContext.getRequest().getHeader("USER-AGENT").toLowerCase().indexOf("msie") > 0 ? true : false;
}
这样试试。
------解决方案--------------------
根据ServletActionContext.getRequest().getHeader("USER-AGENT")判断,不同浏览器不一样值
转载于:https://my.oschina.net/905430/blog/655250