Servlet被服務器實例化後,容器運行其init方法,請求到達時運行其service方法,service方法自動派遣運行與請求對應的doXXX方法(doGet,doPost)等
,當服務器決定將實例銷燬的時候調用其destroy方法
。html
與CGI的區別在於Servlet處於服務器進程中,它經過多線程方式運行其service方法,一個實例能夠服務於多個請求
,而且其實例通常不會銷燬,而CGI對每一個請求都產生新的進程
,服務完成後就銷燬,因此效率上低於servlet。java
forward是服務器內部請求資源
,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,而後把這些內容再發給瀏覽器,瀏覽器根本不知道服務器發送的內容是從哪兒來的,因此它的地址欄中仍是原來的地址。sql
redirect就是服務端根據邏輯,發送一個狀態碼,告訴瀏覽器從新去請求那個地址,通常來講瀏覽器會用剛纔請求的全部參數從新請求,因此session,request參數均可以獲取。後端
動態INCLUDE用jsp:include動做實現 <jsp:include page="included.jsp" flush="true" />
它老是會檢查所含文件中的變化
,適合用於包含動態頁面,而且能夠帶參數。設計模式
靜態INCLUDE用include僞碼實現,不會檢查所含文件的變化
,適用於包含靜態頁面<%@ include file="included.htm" %>
數組
request
表示HttpServletRequest對象。它包含了有關瀏覽器請求的信息,而且提供了幾個用於獲取cookie, header, 和session數據的有用的方法。瀏覽器
response
表示HttpServletResponse對象,並提供了幾個用於設置送回瀏覽器的響應的方法(如cookies,頭信息等)。安全
out
對象是javax.jsp.JspWriter的一個實例,並提供了幾個方法使你能用於向瀏覽器回送輸出結果。bash
pageContext
表示一個javax.servlet.jsp.PageContext對象。它是用於方便存取各類範圍的名字空間、servlet相關的對象的API,而且包裝了通用的servlet相關功能的方法。服務器
session
表示一個請求的javax.servlet.http.HttpSession對象。Session能夠存貯用戶的狀態信息。
applicaton
表示一個javax.servle.ServletContext對象。這有助於查找有關servlet引擎和servlet環境的信息。
config
表示一個javax.servlet.ServletConfig對象。該對象用於存取servlet實例的初始化參數。
page
表示從該頁面產生的一個servlet實例。
<%@page language=」java」 contenType=」text/html;charset=gb2312」 session=」true」 buffer=」64kb」 autoFlush=」true」 isThreadSafe=」true」 info=」text」 errorPage=」error.jsp」 isErrorPage=」true」 isELIgnored=」true」 pageEncoding=」gb2312」 import=」java.sql.*」%>
複製代碼
isErrorPage(是否能使用Exception對象),isELIgnored(是否忽略表達式)
<%@include file=」filename」%>
<%@taglib prefix=」c」uri=」http://……」%>
Jsp頁面中的form標籤裏的method屬性爲get時調用doGet(),爲post時調用doPost()。
<%@ page isThreadSafe=」false」%>
request,session,application,cookie等
JSP 是Servlet技術的擴展
,本質上是Servlet的簡易方式,更強調應用的外表表達。JSP編譯後是"類servlet"
。Servlet和JSP最主要的不一樣點在於,Servlet的應用邏輯是在Java文件中,而且徹底從表示層中的HTML裏分離開來。而JSP的狀況是Java和HTML能夠組合成一個擴展名爲.jsp的文件。JSP側重於視圖,Servlet主要用於控制邏輯
。
page
是表明與一個頁面相關的對象和屬性。一個頁面由一個編譯好的 Java servlet 類(能夠帶有任何的 include 指令,可是沒有 include 動做)表示。這既包括 servlet 又包括被編譯成 servlet 的 JSP 頁面。
request
是表明與 Web 客戶機發出的一個請求相關的對象和屬性。一個請求可能跨越多個頁面,涉及多個 Web 組件(因爲 forward 指令和 include 動做的關係)。
session
是表明與用於某個 Web 客戶機的一個用戶體驗相關的對象和屬性。一個 Web 會話能夠也常常會跨越多個客戶機請求。
application
是表明與整個 Web 應用程序相關的對象和屬性。這實質上是跨越整個 Web 應用程序,包括多個頁面、請求和會話的一個全局做用域。
setAttribute(String name,Object)
:設置名字爲name的request的參數值
getAttribute(String name)
:返回由name指定的屬性值
getAttributeNames()
:返回request對象全部屬性的名字集合,結果是一個枚舉的實例
getCookies()
:返回客戶端的全部Cookie對象,結果是一個Cookie數組
getCharacterEncoding()
:返回請求中的字符編碼方式
getContentLength()
:返回請求的Body的長度
getHeader(String name)
:得到HTTP協議定義的文件頭信息
getHeaders(String name)
:返回指定名字的request Header的全部值,結果是一個枚舉的實例
getHeaderNames()
:返回因此request Header的名字,結果是一個枚舉的實例
getInputStream()
:返回請求的輸入流,用於得到請求中的數據
getMethod()
:得到客戶端向服務器端傳送數據的方法
getParameter(String name)
:得到客戶端傳送給服務器端的有name指定的參數值
getParameterNames()
:得到客戶端傳送給服務器端的全部參數的名字,結果是一個枚舉的實例
getParameterValues(String name)
:得到有name指定的參數的全部值
getProtocol()
:獲取客戶端向服務器端傳送數據所依據的協議名稱
getQueryString()
:得到查詢字符串
getRequestURI()
:獲取發出請求字符串的客戶端地址
getRemoteAddr()
:獲取客戶端的IP地址
getRemoteHost()
:獲取客戶端的名字
getSession([Boolean create])
:返回和請求相關Session
getServerName()
:獲取服務器的名字
getServletPath()
:獲取客戶端所請求的腳本文件的路徑
getServerPort()
:獲取服務器的端口號
removeAttribute(String name)
:刪除請求中的一個屬性
J2EE自己是一個標準
,一個爲企業分佈式應用的開發提供的標準平臺。J2EE也是一個框架,包括JDBC、JNDI、RMI、JMS、EJB、JTA等技術。
J2EE是一套全然不一樣於傳統應用開發的技術架構,包含許多組件,主要可簡化且規範應用系統的開發與部署,進而提升可移植性、安全與再用價值,其核心是一組技術規範與指南,其中所包含的各種組件、服務架構及技術層次,均有共通的標準及規格,讓各類依循J2EE架構的不一樣平臺之間,存在良好的兼容性,解決過去企業後端使用的信息產品彼此之間沒法兼容,致使企業內部或外部難以互通的窘境。
public void init(ServletConfig config) public ServletConfig getServletConfig() public String getServletInfo() public void service(ServletRequest request,ServletResponse response) public void destroy() 複製代碼
Web容器
: 給處於其中的應用程序組件(JSP,SERVLET)提供一個環境,使JSP,SERVLET直接更容器中的環境變量接口交互,沒必要關注其它系統問題。主 要有WEB服務器來實現。例如:TOMCAT,WEBLOGIC,WEBSPHERE等。該容器提供的接口嚴格遵照J2EE規範中的WEB APPLICATION 標準。咱們把遵照以上標準的WEB服務器就叫作J2EE中的WEB容器。
EJB容器
:Enterprise java bean 容器。更具備行業領域特點。他提供給運行在其中的組件EJB各類管理功能。只要知足J2EE規範的EJB放入該容器,立刻就會被容器進行高效率的管理。而且能夠經過現成的接口來得到系統級別的服務。例如郵件服務、事務管理。
JNDI
:(Java Naming & Directory Interface)JAVA命名目錄服務。主要提供的功能是:提供一個目錄系統,讓其它各地的應用程序在其上面留下本身的索引,從而知足快速查找和定位分佈式應用程序的功能。
JMS
:(Java Message Service)JAVA消息服務。主要實現各個應用程序之間的通信。包括點對點和廣播。
JTA
:(Java Transaction API)JAVA事務服務。提供各類分佈式事務服務。應用程序只需調用其提供的接口便可。
JAF
:(Java Action FrameWork)JAVA安全認證框架。提供一些安全控制方面的框架。讓開發者經過各類部署和自定義實現本身的個性安全控制策略。
RMI/IOP
: (Remote Method Invocation /internet對象請求中介協議)他們主要用於經過遠程調用服務。例如,遠程有一臺計算機上運行一個程序,它提供股票分析服務,咱們能夠在本地計算機 上實現對其直接調用。固然這是要經過必定的規範才能在異構的系統之間進行通訊。RMI是JAVA特有的。
MVC 是Model-View-Controller的簡寫。"Model" 表明的是應用的業務邏輯(經過JavaBean,EJB組件實現), "View" 是應用的表示面(由JSP頁面產生),"Controller" 是提供應用的處理過程控制(通常是一個Servlet),經過這種設計模型把應用邏輯,處理過程和顯示邏輯分紅不一樣的組件實現。這些組件能夠進行交互和重 用。
JSP 共有如下6種基本動做:
jsp:include
:在頁面被請求的時候引入一個文件。jsp:useBean
:尋找或者實例化一個JavaBean。jsp:setProperty
:設置JavaBean的屬性。jsp:getProperty
:輸出某個JavaBean的屬性。jsp:forward
:把請求轉到一個新的頁面。jsp:plugin
:根據瀏覽器類型爲Java插件生成OBJECT或EMBED標記。
Cookie機制採用的是在客戶端保持狀態
的方案,而session機制採用的是在服務器端保持狀態
的方案。
Cookie機制
:正統的Cookie分發是經過 擴展HTTP協議來實現的,服務器經過 在HTTP的響應頭中加上一行特殊的指示 以提示瀏覽器按照指示生成相應的Cookie。然而純粹的客戶端腳本如JavaScript或者VBScript也能夠生成Cookie。而Cookie的使用是由瀏覽器按照必定的原則在後臺自動發送給服務器的。瀏覽器檢查全部存儲的Cookie,若是某個Cookie所聲明的做用範圍大於等於將要請求的資源所在的位置,則把該Cookie附在請求資源的HTTP請求頭上發送給服務器。
Cookie的內容主要包括:名字,值,過時時間,路徑和域。路徑與域一塊兒構成Cookie的做用範圍。若不設置過時時間,則表示這個Cookie的生命期爲瀏覽器會話期間,關閉瀏覽器窗口,Cookie就消失
。這種生命期爲瀏覽器會話期的Cookie被稱爲會話Cookie。
會話Cookie通常不存儲在硬盤上而是保存在內存裏
,固然這種行爲並非規範規定的。若設置了過時時間,瀏覽器就會把Cookie保存到硬盤上
,關閉後再次打開瀏覽器,這些Cookie 仍然有效直到超過設定的過時時間。存儲在硬盤上的Cookie 能夠在不一樣的瀏覽器進程間共享,好比兩個IE窗口。而對於保存在內存裏的Cookie ,不一樣的瀏覽器有不一樣的處理方式 。
Session機制:session機制是一種服務器端的機制,服務器使用一種相似於散列表的結構(也可能就是使用散列表)來保存信息。
當程序須要爲某個客戶端的請求建立一個session時,服務器首先檢查這個客戶端的請求裏是否已包含了一個session標識(稱爲session id),若是已包含則說明之前已經爲此客戶端建立過session,服務器就按照session id把這個session檢索出來使用(檢索不到,會新建一個),若是客戶端請求不包含session id,則爲此客戶端建立一個session而且生成一個與此session相關聯的session id,session id的值應該是一個既不會重複,又不容易被找到規律以仿造的字符串,這個session id將被在本次響應中返回給客戶端保存。保存這個session id的方式能夠採用Cookie
,這樣在交互過程當中瀏覽器能夠自動的按照規則把這個標識發送給服務器。通常這個cookie的名字都是相似於SEEESIONID
。但Cookie 能夠被人爲的禁止,則必須有其餘機制以便在cookie被禁止時仍然可以把session id傳遞迴服務器。
常常被使用的一種技術叫作 URL重寫
,就是把session id直接附加在URL路徑的後面。
還有一種技術叫作 表單隱藏字段
。就是服務器會自動修改表單,添加一個隱藏字段,以便在表單提交時可以把session id傳遞迴服務器。好比:
<form name="testform" action="/xxx">
<input type="hidden" name="jsessionid" value="ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764">
<input type="text">
</form>
複製代碼
實際上這種技術能夠簡單的用對action應用URL重寫來代替。
Cookie 和Session 的區別:
- cookie數據存放在客戶的瀏覽器上,session數據放在服務器上。
- cookie不是很安全,別人能夠分析存放在本地的COOKIE並進行COOKIE欺騙,考慮到安全應當使用session。
- session會在必定時間內保存在服務器上。當訪問增多,會比較佔用你服務器的性能,考慮到減輕服務器性能方面,應當使用 COOKIE。
- 單個cookie在客戶端的限制是3K,就是說一個站點在客戶端存放的COOKIE不能3K。
JSP共有如下9種基本內置組件(可與ASP的6種內部組件相對應):
request
用戶端請求,此請求會包含來自GET/POST請求的參數response
網頁傳回用戶端的迴應pageContext
網頁的屬性是在這裏管理session
與請求有關的會話期application
servlet 正在執行的內容out
用來傳送回應的輸出config
servlet的構架部件page
JSP網頁自己exception
針對錯誤網頁,未捕捉的例外
帶request參數的跳轉
request.setAttribute("param", "value");
request.getRequestDispatcher("test.jsp").forward(request, response);
複製代碼
在目的頁面能夠獲取參數:
String Value = request.getAttribute("param")==null?:(String)request.getAttribute("param");
複製代碼
不帶request參數的跳轉
response.sendredirect("test.jsp");
複製代碼
forward 是服務器內部重定向
,程序收到請求後從新定向到另外一個程序,客戶機並不知道;
redirect則是服務器收到請求後發送一個狀態頭給客戶,客戶將再請求一 次,這裏多了兩次網絡通訊的來往。固然forward也有缺點,就是forward的頁面的路徑若是是相對路徑就會有些問題了。
forward 會將 request state , bean 等等信息帶往下一個 jsp。 redirect 是送到 client 端後再一次 request , 因此資料不被保留。
使用 forward 你就能夠用 getAttribute() 來取的前一個 jsp 所放入的 bean 等資料
forward是服務器請求資源,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,而後把這些內容再發給瀏覽器.瀏覽器根本不知道服務器發送的內容從哪裏來的,因此它的地址欄仍是原來的地址.
redirect是服務端根據邏輯,發送一個狀態碼,告訴瀏覽器從新去請求那個地址.因此地址欄顯示的是新的URL.因此redirect等於客戶端向服務器端發出兩次request,同時也接受兩次response。
forward:轉發頁面和轉發到的頁面能夠共享request裏面的數據. redirect:不能共享數據.redirect不只能夠重定向到當前應用程序的其餘資源,還能夠重定向到同一個站點上的其餘應用程序中的資源,甚至是使用絕對URL重定向到其餘站點的資源. forward,方法只能在同一個Web應用程序內的資源之間轉發請求. forward 是服務器內部的一種操做. redirect 是服務器通知客戶端,讓客戶端從新發起請求. 因此,你能夠說 redirect 是一種間接的請求, 可是你不能說"一個請求是屬於forward仍是redirect "。
forward:通常用於用戶登錄的時候,根據角色轉發到相應的模塊. redirect:通常用於用戶註銷登錄時返回主頁面和跳轉到其它的網站等.
forward:高. redirect:低.
JSP在本質上就是SERVLET,可是二者的建立方式不同.Servlet徹底是JAVA程序代碼構成擅長於流程控制和事務處理而經過Servlet來生成動態網頁;JSP由HTML代碼和JSP標籤構成,能夠方便地編寫動態網頁,所以在實際應用中採用Servlet來控制業務流程,而採用JSP來生成動態網頁.在struts框架中,JSP位於MVC設計模式的視圖層,而Servlet位於控制層.
<jsp:include page="b.jsp" />
<%@ include file="b.jsp" />
區別:
<jsp:include page="b.jsp" />(先執行,後包含)
此標籤表示法:能動態區別加進來的是動態頁面仍是靜態頁面對於靜態頁面則直接將資源包含(僅取其文本)。
<%@ include file="b.jsp">
此指令表示:靜態地包含頁面,無論其內容如何,不過是靜態頁面仍是動態頁面都首先將頁面的內容先加進來
。
<jsp:include page="b.jsp" />能夠傳遞參數,以下:
<jsp:include page="b.jsp" >
<jsp:param name="參數名" value="參數值"/>
</jsp:include>
複製代碼
servlet的轉發方式有兩種:
response.sendRedirect(response.encodeURL(相對路徑或絕對路徑)); request.getRequestDispatcher(相對路徑).forward();
jsp是servlet的擴展,除可用上面兩種以外,還能夠用標籤:
<jsp:forward page="相對路徑" />
複製代碼