一.JSP隱含對象response實現文件下載的介紹
(1)在JSP中實現文件下載最簡單的方法是定義超鏈接指向目標資源,用戶單擊超鏈接後直接下載資源,但直接暴露資源的URL
也會帶來一些負面的影響,例如容易被其它網站盜鏈,造成本地服務器下載負載過重。
(2)另外一種下載文件的方法是使用文件輸出流實現下載,首先通過response報頭告知客戶端浏覽器,將接收到的信息另存
為一個文件,然後用輸出流對象給客戶端傳輸文件數據,浏覽器接收數據完畢後將數據另存為文件,這種下載方法的優點是服
務器端資源路徑的保密性好,並可控制下載的流量以及日志登記等。
二.以下介紹兩種文件的下載方式
(1)二進制文件的下載
用JSP程序下載二進制文件的基本原理是:首先將源文件封裝成字節輸入流對象,通過該對象讀取文件數據,獲取response對象
的字節輸出流對象,通過輸出流對象將二進制的字節數據傳送給客戶端。
1.把源文件封裝成字節輸入流對象
2.讀取二進制字節數據並傳輸給客戶端
代碼如下:
<%@ page contentType="application/x-download" import="java.io.*" %> <% int status=0; byte b[]=new byte[1024]; FileInputStream in=null; ServletOutputStream out2=null; try { response.setHeader("content-disposition","attachment; filename=d.zip"); in=new FileInputStream("c:\\tomcat\\webapps\\ROOT\\d.zip"); out2=response.getOutputStream(); while(status != -1 ) { status=in.read(b); out2.write(b); } out2.flush(); } catch(Exception e) { System.out.println(e); response.sendRedirect("downError.jsp"); } finally { if(in!=null) in.close(); if(out2 !=null) out2.close(); } %>
(2)文本文件下載
文本文件下載時用的是字符流,而不是字節流。首先取得源文件的字符輸入流對象,用java.io.FileReader類封裝,
再把FileReader對象封裝為java.io.BufferedReader,以方便從文本文件中一次讀取一行。字符輸出流直接用JSP的隱
含對象out,out能夠輸出字符數據。
代碼如下:
<%@ page contentType="application/x-download" import="java.io.*" %><% int status=0; String temp=null; FileReader in=null; BufferedReader in2=null; try { response.setHeader("content-disposition","attachment; filename=ee.txt"); response.setCharacterEncoding("gb2312"); in=new FileReader("c:\\tomcat\\webapps\\ROOT\\ee.txt"); in2=new BufferedReader(in); while((temp=in2.readLine()) != null ) { out.println(temp); } out.close(); } catch(Exception e) { System.out.println(e); response.sendRedirect("downError.jsp"); } finally { if(in2!=null) in2.close(); } %>
1、out 來源於java.io.Writer類,它用於發送輸出流到客戶端。
2、request 來源於javax.servlet.http.HttpServletRequest接口。它被關聯到每一個HTTP請求。
3、response 來源於javax.servlet.http.HttpServletResponse。response對象用於把取得的數據返回到客戶端。
4、pageContext 提供訪問JSP頁面的命名空間。它也提供用來訪問其他的JSP隱含對象。
5、session 來源於javax.servlet.http.HttpSession。它用於存儲客戶端請求的信息,因此它是有狀態交互式的。
6、application 來源於javax.servlet.ServletContext。
7、config 來源於ServletConfig,它包含了當前JSP/Servlet所在的WEB應用的配置信息。
8、page 來源於當前被訪問JSP頁面的實例化。它實際使用的是JSP轉換成的Servlet。
9、exception 用於捕獲JSP拋出的異常。它只有在JSP頁面屬性isErrorPage=true時才可用。
1. RequestDispatcher.forward()
在服務器端起作用,當使用forward()時,Servlet engine傳遞HTTP請求從當前的Servlet或者是JSP到另外的一個Servlet、JSP 或普通HTML文件,也即你的form提交至a.jsp,在a.jsp用到了forward()重定向至b.jsp,此時form提交的所有信息在 b.jsp都可以獲得,參數自動傳遞. 但forward()無法重定向至有frame的jsp文件,可以重定向至有frame的html文件,同時forward()無法在後面帶參數傳遞,比如servlet?name=frank,這樣不行,可以程序內通過response.setAttribute("name",name)來傳至下一個頁面。
重定向後浏覽器地址欄URL不變。
例:在servlet中進行重定向
public void doPost(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
response.setContentType("text/html; charset=gb2312");
ServletContext sc = getServletContext();
RequestDispatcher rd = null;
rd = sc.getRequestDispatcher("/index.jsp"); //定向的頁面
rd.forward(request, response);
}
通常在servlet中使用,不在jsp中使用。
2. response.sendRedirect()
在用戶的浏覽器端工作,sendRedirect()可以帶參數傳遞,比如servlet?name=frank傳至下個頁面,同時它可以重定向至不同的主機上,sendRedirect()可以重定向有frame.的jsp文件.
重定向後在浏覽器地址欄上會出現重定向頁面的URL。
例:在servlet中重定向
public void doPost(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
response.setContentType("text/html; charset=gb2312");
response.sendRedirect("/index.jsp");
}
由於response是jsp頁面的隱含對象,故在jsp頁面中可用response.sendRedirect()直接實現重定位。
注意:
(1) 使用response.sendRedirect時,前面不能有HTML輸出;
這並不是絕對的,不能有HTML輸出其實是指不能有HTML被送到了浏覽器。事實上現在的server都有cache機制,一般在8K(我是說 JSP SERVER),這就意味著,除非你關閉了ca......余下全文>>