public void downLoad(HttpServletRequest request,HttpServletResponse response, boolean isOnLine) throws Exception {
String fileName = "ODS报表系统指标地图.xlsx";
//获取项目根目录
String path2 = File.separator+"WEB-INF"+File.separator+"PICC-File.xlsx";
InputStream path = request.getSession().getServletContext().getResourceAsStream(path2);
String ext = fileName.substring(fileName.lastIndexOf(".") + 1);
String agent = (String) request.getHeader("USER-AGENT"); //判断浏览器类型
try {
if (agent != null && agent.indexOf("Firefox") != -1) {
fileName = new String(fileName.getBytes("UTF-8"), "iso-8859-1");//UTF-8编码,防止输出文件名乱码
} else {
fileName = URLEncoder.encode(fileName, "UTF-8");
}
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
BufferedInputStream bis = null;
OutputStream os = null;
response.reset();
response.setCharacterEncoding("utf-8");
if ("xlsx".equals(ext)) {
response.setContentType("application/xlsx"); // xlsx格式
} else if ("doc".equals(ext)) {
response.setContentType("application/msword"); // word格式
}else if (ext == "pdf") {
response.setContentType("application/pdf"); // pdf格式
}
response.setHeader("Content-Disposition", "attachment; filename=" + fileName);
try {
bis = new BufferedInputStream(path);
byte[] b = new byte[bis.available() + 1000];
int i = 0;
os = response.getOutputStream(); //直接下载导出
while ((i = bis.read(b)) != -1) {
os.write(b, 0, i);
}
os.flush();
os.close();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (os != null) {
try {
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
版权声明:本文为WZY_snail原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。