頁面類:
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();
