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();
posted @ 2019-01-15 14:06  xuejianbest  阅读(2984)  评论(0编辑  收藏  举报