您好,登錄后才能下訂單哦!
小編給大家分享一下Servlet方法生命周期及執行原理的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
定義一個類,實現Servlet
接口
public class ServletDemo1 implements Servlet { /** * 初始化方法 * 在Servlet被創建時,執行。只會執行一次 * @param servletConfig * @throws ServletException * */ @Override public void init(ServletConfig servletConfig) throws ServletException { System.out.println("init......"); } /** * 獲取ServletConfig對象 * ServletCongig:Servlet的配置對象 * @return * */ @Override public ServletConfig getServletConfig() { return null; } /** * 提供服務方法 * 每一次Servlet被訪問時,執行。可執行多次 * @param servletRequest * @param servletResponse * @throws ServletException * @throws IOException * */ @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { System.out.println("服務小皮皮美滋滋!"); } /** * 獲取Servlet的一些詳細,版本,作者等等 * @return * */ @Override public String getServletInfo() { return null; } /** * 銷毀方法 * 在服務器正常關閉時執行。執行一次 * */ @Override public void destroy() { System.out.println("服務關閉了..."); } }
配置Servlet
在web.xml
中配置
<!--配置Servlet --> <servlet> <servlet-name>demo1</servlet-name> <servlet-class>xppmzz.ServletDemo1</servlet-class> </servlet> <servlet-mapping> <servlet-name>demo1</servlet-name> <url-pattern>/demo1</url-pattern> </servlet-mapping>
點擊IDEA中Tomcat的啟動按鈕,在瀏覽器中輸入http://localhost:8080/demo1
。
觀察IDEA輸出窗口輸出內容。
當服務器接受到客戶端瀏覽器的請求后,會解析請求URL
路徑,獲取訪問的Servlet
的資源路徑。
查找web.xm
l文件,是否有對應的<url-pattern>
標簽體內容。
如果有,則在找到對應的<servlet-class>
全類名。
tomcat
會將字節碼文件加載進內存,并且創建其對象。
調用其方法。
Servlet什么時候被創建?
默認情況下,第一次被訪問時,Servlet被創建。
可以配置執行Servlet的創建時機。
在<servlet>
標簽下配置:
第一次被訪問時,創建<load-on-startup>
的值為負數。
在服務器啟動時,創建<load-on-startup>
的值為0或正整數。
<servlet> <servlet-name>demo1</servlet-name> <servlet-class>xppmzz.ServletDemo1</servlet-class> <load-on-startup>5</load-on-startup> </servlet>
如果為負數,則在瀏覽器中第一次輸入http://localhost:8080/demo1
才會執行init
方法。0或者正整數會在Tomcat
第一次啟動時執行init
方法。
Servlet的init方法,只執行一次,說明一個Servlet在內存中只存在一個對象,Servlet是單例的。
因此,多個用戶同時訪問時,可能存在線程安全問題。
解決:盡量不要在Servlet中定義成員變量。即使定義了成員變量,也不要對修改值
每次訪問Servlet時,Service方法都會被調用一次。
Servlet被銷毀時執行。服務器關閉時,Servlet被銷毀。
只有服務器正常關閉時,才會執行destroy方法。
destroy方法在Servlet被銷毀之前執行,一般用于釋放資源。
好處:支持注解配置,可以不需要web.xml
。
步驟:
創建JavaEE項目,選擇Servlet的版本3.0以上,可以不創建web.xml。
定義一個類,實現Servlet接口。
復寫方法。
在類上使用@WebServlet
注解,進行配置。@WebServlet("資源路徑")
代碼示例:
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface WebServlet { String name() default "";//相當于<Servlet-name> String[] value() default {};//代表urlPatterns()屬性配置 String[] urlPatterns() default {};//相當于<url-pattern> int loadOnStartup() default -1;//相當于<load-on-startup> WebInitParam[] initParams() default {}; boolean asyncSupported() default false; String smallIcon() default ""; String largeIcon() default ""; String description() default ""; String displayName() default ""; }
Servlet
– 接口
GenericServlet
– 抽象類
HttpServlet
– 抽象類
將Servlet
接口中其他的方法做了默認空實現,只將service()
方法作為抽象。
將來定義Servlet類時,可以繼承GenericServlet,實現service()方法即可
@WebServlet("/demo2") public class ServletDemo2 extends GenericServlet { @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { System.out.println("GenericServlet...."); } }
對http
協議的一種封裝,簡化操作。
定義類繼承HttpServlet
。
復寫doGet
/doPost
方法。
@WebServlet("/demo3") public class ServletDemo3 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { System.out.println("doGet......"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { System.out.println("doPost......"); } }
urlpartten
:Servlet
訪問路徑。
一個Servlet可以定義多個訪問路徑 : @WebServlet({"/d4","/dd4","/ddd4"})
路徑定義規則:/xxx
:路徑匹配。/xxx/xxx
:多層路徑,目錄結構。*.do
:擴展名匹配。
以上是“Servlet方法生命周期及執行原理的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。