1. 程式人生 > >1.Jsp的九大物件以及作用

1.Jsp的九大物件以及作用

1.Jsp的九大物件以及作用

1>out 向客戶端輸出資料,位元組流.out.print(" dgaweyr");
 
2>request 接收客戶端的http請求.
String getParameter(String name):得到表單引數名name的值.
String[] getParameterValues(String name):(得到String[]複選框時常用).
setAttribute(String name,Object obj):設定屬性名為
name,屬性值為obj.

getAttribute(String name);得到屬性值.
 
3>response:封裝jsp產生的迴應,然後傳送到客戶端以響應客戶的請求.重定向跳轉任意介面.(伺服器跳轉)
addCookie(Cookie cookie):
sendRedirect("/wel.jsp"):跳轉到指定頁面
 
4>session:用於儲存使用者資訊,跟蹤使用者行為,當前開啟的瀏覽器內,多個頁面共享資料. session物件指的是客戶端與伺服器的一次會話
,從客戶連到伺服器的一個WebApplication開始,直到客戶端與伺服器斷開連線為止.它是HttpSession類的例項.

setAttribute(String name,Object obj):設定屬性名為name,屬性值為obj.
getAttribute(String name):得到屬性值.
 
5>application物件:實現了使用者間資料的共享,可存放全域性變數.它開始於伺服器的啟動,直到伺服器的關閉,在此期間,此物件將一直存在;這樣在使用者的前後連線或不同使用者之間的連線中,
可以對此物件的同一屬性進行操作;在任何地方對此物件屬性的操作,都將影響到其他使用者對此的訪問.伺服器的啟動和關閉決定了application物件的生命.它是ServletContext類的例項.

 
session,application,request的區別:
一個專案中session儘量少用幾個,因為過多的session會影響程式的執行效率.它主要用於儲存登入資訊(使用者資訊,許可權,資源)即頻繁使用的資訊.
application: 用於多個瀏覽器之間共享資料,多個使用者共享該物件,可以做計數器.它的用法與session完全一樣.
資料範圍:
application(伺服器關閉時失效)>session(瀏覽器關閉時失效)>request(只能用於兩個跳轉頁面之間)
 
6>page物件代表jsp這個實體本身,即當前頁面有效.相當於java中的this.
資料範圍:page<session<application
 
7>.exception:代表執行時的異常.
在會發生異常的頁面加入指令:<%@ page errorPage="處理錯誤的頁面.jsp"%>
在處理異常的頁面寫入:<%@ page isErrorPage="true"%>
 
8>.pageContext物件 pageContext物件提供了對JSP頁面內所有的物件及名字空間的訪問,也就是說他可以訪問到本頁所在的SESSION,也可以取本頁面所在的application的某一屬性值,他相當於頁面中所有功能的集大成者,它的本類名也叫pageContext.
 
9>.config jsp對應的servlet的配置,可以得到web.xml中的初使化引數.


2靜態include指令、動態Include指令區別

(1)靜態匯入(include指令)通過file屬性指定被包含的檔案,並且file屬性不支援任何表示式;動態匯入(include動作)通過page屬性指定被包含的檔案,且page屬性支援JSP表示式;

(2)使用靜態匯入(include指令)時,被包含的檔案內容會原封不動的插入到包含頁中,然後JSP編譯器再將合成後的檔案最終編譯成一個Java檔案;使用動態匯入(include動作)包含檔案時,當該標識被執行時,程式會將請求轉發(不是請求重定向)到被包含的頁面,並將執行結果輸出到瀏覽器中,然後返回包含頁繼續執行後面的程式碼。因為伺服器執行的是多個檔案,所以JSP編譯器會分別對這些檔案進行編譯;

(3)使用include指令包含檔案時,由於被包含的檔案最終會生成一個檔案,所以在被包含、包含檔案中不能有重名的變數或方法;而include動作包含檔案時,由於每個檔案是單獨編譯的,所以在被包含檔案和包含檔案中重名的變數和方法是不相沖突的。

(4)靜態匯入是將被匯入頁面的程式碼完全融入,兩個頁面融合成一個整體Servlet,因此被匯入頁面甚至不需要是一個完整的頁面;而動態匯入則在Servlet中使用include方法來引入被匯入頁面的內容;

(5)靜態匯入時被匯入頁面的編譯指令會起作用;而動態匯入時被匯入頁面的編譯指令則失去作用,只是插入被匯入頁面的body內容。


3.Servlet生命週期分為三個階段:

  1,初始化階段  呼叫init()方法

  2,響應客戶請求階段  呼叫service()方法

  3,終止階段  呼叫destroy()方法

Servlet初始化階段:

  在下列時刻Servlet容器裝載Servlet:

    1,Servlet容器啟動時自動裝載某些Servlet,實現它只需要在web.XML檔案中的<Servlet></Servlet>之間新增如下程式碼:

<loadon-startup> 1 </loadon-startup>

    2,在Servlet容器啟動後,客戶首次向Servlet傳送請求

    3,Servlet類檔案被更新後,重新裝載Servlet

  Servlet被裝載後,Servlet容器建立一個Servlet例項並且呼叫Servlet的init()方法進行初始化。在Servlet的整個生命週期內,init()方法只被呼叫一次。

    

Servlet工作原理:

  首先簡單解釋一下Servlet接收和響應客戶請求的過程,首先客戶傳送一個請求,Servlet是呼叫service()方法對請求進行響應的,通過原始碼可見,service()方法中對請求的方式進行了匹配,選擇呼叫doGet,doPost等這些方法,然後再進入對應的方法中呼叫邏輯層的方法,實現對客戶的響應。在Servlet介面和GenericServlet中是沒有doGet,doPost等等這些方法的,HttpServlet中定義了這些方法,但是都是返回error資訊,所以,我們每次定義一個Servlet的時候,都必須實現doGet或doPost等這些方法。

  每一個自定義的Servlet都必須實現Servlet的介面,Servlet介面中定義了五個方法,其中比較重要的三個方法涉及到Servlet的生命週期,分別是上文提到的init(),service(),destroy()方法。GenericServlet是一個通用的,不特定於任何協議的Servlet,它實現了Servlet介面。而HttpServlet繼承於GenericServlet,因此HttpServlet也實現了Servlet介面。所以我們定義Servlet的時候只需要繼承HttpServlet即可。

  Servlet介面和GenericServlet是不特定於任何協議的,而HttpServlet是特定於HTTP協議的類,所以HttpServlet中實現了service()方法,並將請求ServletRequest,ServletResponse強轉為HttpRequest和HttpResponse。

public  void  service(ServletRequest req,ServletResponse res)    throws  ServletException,IOException {        HttpRequest request;        HttpResponse response;         try       {           req = (HttpRequest)request;           res = (HttpResponse)response;        } catch (ClassCastException e)        {           throw  new  ServletException( "non-HTTP request response" );        }        service(request,response); }

    程式碼的最後呼叫了HTTPServlet自己的service(request,response)方法,然後根據請求去呼叫對應的doXXX方法,因為HttpServlet中的doXXX方法都是返回錯誤資訊,

protected  void  doGet(HttpServletRequest res,HttpServletResponse resp)    throws  ServletException,IOException {     String protocol = req.getProtocol();     String msg = IStrings.getString( "http.method_get_not_supported" );     if (protocol.equals( "1.1" ))     {        resp.sendError(HttpServletResponse.SC.METHOD.NOT.ALLOWED,msg);      }     esle      {        resp.sendError(HttpServletResponse.SC_BAD_REQUEST,msg);      } }

所以需要我們在自定義的Servlet中override這些方法!


4. java中4中修飾符分別為public、protect、default、private,詳細講述下它們的訪問許可權問題。(同一個類中除內部類外所有修飾符都是可以訪問的,所以下面排除這種情況。)

    首先在這裡把它們的訪問許可權表示出來:

    訪問許可權   類   包  子類  其他包

    public     ∨   ∨   ∨     ∨

    protect    ∨   ∨   ∨     ×

    default    ∨   ∨   ×     ×

    private    ∨   ×   ×     ×