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

java

页面类:

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

回到顶部