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):設定屬性名為
getAttribute(String name);得到屬性值.
3>response:封裝jsp產生的迴應,然後傳送到客戶端以響應客戶的請求.重定向跳轉任意介面.(伺服器跳轉)
addCookie(Cookie cookie):
sendRedirect("/wel.jsp"):跳轉到指定頁面
4>session:用於儲存使用者資訊,跟蹤使用者行為,當前開啟的瀏覽器內,多個頁面共享資料. session物件指的是客戶端與伺服器的一次會話
setAttribute(String name,Object obj):設定屬性名為name,屬性值為obj.
getAttribute(String name):得到屬性值.
5>application物件:實現了使用者間資料的共享,可存放全域性變數.它開始於伺服器的啟動,直到伺服器的關閉,在此期間,此物件將一直存在;這樣在使用者的前後連線或不同使用者之間的連線中,
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 ∨ × × ×