jsp下载文件时,如果连接地址为文件地址。那么可以下载;
但很多时候为了安全性,或者是使用spring 框架后,url为文档路径将不被处理,那么我们又该怎么下载文档呢?
下面是一个jsp页面负责下载页面
原理是:
1、
response.setContentType("application/octet-stream"); // 告诉服务器向浏览器发送数据属于什么样文件类型
response.setHeader("Content-Disposition","attachment; filename=\"" +URLEncoder.encode("文档.xls","utf-8")+ "\"");
//中指定的类型是文件的扩展名,并且弹出的下载对话框中的文件类型图片是按照文件的扩展名显示的,点保存后,文件以filename的值命名,保存类型以Content中设置的为
//准。
2、
利用文件流处理,将服务器端文件 以文件流方式读取后,以输出流写到客户端
源代码:
<%@page contentType="text/html;charset=utf-8"%>
<%@ page import="java.io.*"%>
<%
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", -1);
response.reset();
String filePath=request.getParameter("filePath");
if(filePath == null || "".endsWith(filePath)){
System.out.println("文件地址为空,非法访问,IP:" + request.getLocalAddr());
out.print("对不起,文件不存在");
return ;
}
System.out.println("开始从:" + filePath + "下载文件");
File file = new File(filePath);
if(file.exists())
{
response.setContentType("application/octet-stream");
response.setHeader("Content-Disposition","attachment; filename=\"" +URLEncoder.encode("文档.xls","utf-8")+ "\"");
try
{
OutputStream os = null;
os = response.getOutputStream(); //不加此行将只能下载文本文件.下载jpg等就会出现打不开的现象
java.io.FileInputStream fis = new java.io.FileInputStream(filePath);
System.out.println("开始从:" + filePath + "下载文件");
byte[] b = new byte[1024];
int i = 0;
while ((i = fis.read(b))!= -1)
{
os.write(b, 0, i);
}
fis.close();
os.flush();
os.close();
}
catch ( Exception e )
{
System.out.println ( "IOException." + e );
}
out.clear();
out = pageContext.pushBody();
}else
{
%>
<%@page import="java.net.URLEncoder"%>
<html>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<h1>sorry,file not found!</h1>
</html>
<%
}
%>