Java Web:下载服务器上的文件

Java Web文件下载与Excel导出
本文详细介绍了在Java Web应用中实现文件下载的方法,包括设置响应头、读取服务器文件并将其发送到客户端的过程。同时,文章还提供了生成Excel文件并提供下载的示例代码,展示了如何创建Excel工作表、设置列宽、填充数据,并设置响应类型以触发文件下载。

页面类:

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();

转载于:https://www.cnblogs.com/xuejianbest/p/10284939.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值