代码:
一:判断浏览器类型;
OutputStream os=response.getOutputStream();
String agent = request.getHeader("USER-AGENT");
boolean isIE=false;//检查是否是ie浏览器,;
if (null != agent && agent.indexOf("MSIE")!=-1) {
isIE=true;
}
二:根据浏览器类型,对文件名进行不同的编码;
List<String[]> resultList=。。。。。
String[] headers={"监测目标","最近响应时间"};
//开始导出数据;
response.reset();
response.setContentType("application/vnd.ms-excel;charset=UTF-8");
HSSFWorkbook hf = ExcelUtil.createExcel(“sheet名”,headers,resultList);
String fileName = "响应时间监测"+".xls";
if(isIE){//如果是ie浏览器,就用这种方式编码文件名;
fileName=URLEncoder.encode(fileName, "UTF-8");
}else{//firforx则编码成iso-8859-1
fileName=new String(fileName.getBytes("utf-8"),"ISO-8859-1");
}
response.addHeader("Content-Disposition","attachment;filename="+fileName );
hf.write(os);
os.flush();
os.close();
response.flushBuffer();