Java Web:下载服务器上的文件
页面类:
public void doDownTemplet(HttpServletRequest request, HttpServletResponse response) throws IOException{ response.setContentType("text/xml");
response.setHeader("Content-Disposition", "attachment;filename=abc.xml");
ServletContext ctx = request.getSession().getServletContext();
InputStream is = ctx.getResourceAsStream("abc.xml");
OutputStream os = response.getOutputStream();
byte[] buffer = new byte[1024];
int i = -1;
while ((i = is.read(buffer)) != -1) {
os.write(buffer, 0, i);
}
os.flush();
os.close();
}
设置文件类型,如:
response.setContentType("application/pdf;charset=UTF-8");response.setContentType("application/msexcel;charset=UTF-8");
response.setContentType("application/msword;charset=UTF-8");
指定要下载的服务器文件位置:
InputStream is = ctx.getResourceAsStream("abc.xml");//此方法路径从WebContent跟路径开始,如/web/abc.xml,路径为WebContent/web/abc.xml.
//也可以采用绝对路径:
String fileDir = ctx.getRealPath("/");
String fileName = "abc.xml";
File file = new File(fileDir, fileName);
FileInputStream fis = new FileInputStream(file);
BufferedInputStream bis = new BufferedInputStream(fis);
前端js:
window.open ("DownFile.do?method=DownTemplet");
Content-Disposition
是 MIME 协议的扩展,MIME 协议指示 MIME 用户代理如何显示附加的文件。当 Internet Explorer 接收到头时,它会激活文件下载对话框,它的文件名框自动填充了头中指定的文件名。(请注意,这是设计导致的;无法使用此功能将文档保存到用户的计算机上,而不向用户询问保存位置。)
服务端向客户端浏览器发送文件时,如果是浏览器支持的文件类型,一般会默认使用浏览器打开,比如txt、jpg等,会直接在浏览器中显示,如果需要提示用户保存,就要利用Content-Disposition
进行一下处理,关键在于一定要加上attachment:
Response.AppendHeader("Content-Disposition","attachment;filename=FileName.txt");
注意事项:
当代码里面使用Content-Disposition
来确保浏览器弹出下载对话框的时候。 response.addHeader("Content-Disposition","attachment");
一定要确保没有做过关于禁止浏览器缓存的操作。如下:
response.setHeader("Pragma", "No-cache"); response.setHeader("Cache-Control", "No-cache");
response.setDateHeader("Expires", 0);
不然会发现下载功能在opera和firefox里面好好的没问题,在IE下面找不到文件。
生成excel并提供下载:
List<Map<String, Object>> data; //要写入excel的数据List<String> columns; //下载的文件的表头
Workbook wb = new HSSFWorkbook();
//Workbook wb = new XSSFWorkbook();
Sheet sheet = wb.createSheet("工作表1");
sheet.setColumnWidth(0, 256*20);
Row row = sheet.createRow(0);
int i = 0;
for(String col : columns){
row.createCell(i++).setCellValue(col);
}
i = 1;
for(Map<String, Object> map : data){
Row row_value = sheet.createRow(i++);
int col_num = 0;
for(String col : columns){
String v1 = map.get(col).toString();
row_value.createCell(col_num++).setCellValue(v1);
}
}
response.setContentType("application/msexcel;charset=UTF-8");
response.setHeader("Content-Disposition", "attachment;filename=data.xls");
OutputStream os = response.getOutputStream();
wb.write(os);
os.flush();
os.close();
以上是 Java Web:下载服务器上的文件 的全部内容, 来源链接: utcz.com/z/390612.html