成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在Servlet中如何添加web框架

開發 后端
在servlet中如何添加web框架呢?通過本文的介紹,實現了將Web請求轉到了webwork中的控制器ServletDispatcher。不止是webwork,實現MVC的web框架都需要進行類似的處理來將web請求轉入到自己的controller.以便進行進一步的處理。

init()方法

init方法在容器器裝入servlet 時執行,servlet容器在實例化后只調用一次init方法,init方法必須在servlet接收到任何請求之前完成。

這個方法通常用來進行一些資源的管理和初始化,如從配置文件讀取配置數據,讀取初始化參數,初始化緩沖遲等一次性的操作。

getservletConfig()方法

GetservletConfig方法返回一個 servletConfig 對象,該對象用來返回這個servlet的初始化信息和啟動參數。返回的是傳遞到init方法servletConfig。

Service()方法

Service方法是應用程序邏輯的進入點,是Servlet方法的核心,WEB容器調用這個方法來響應進入的請求,只有servlet成功被init()方法初始化后,Service方法才會被調用。

getservletInfo()方法

這個方法返回一個字符串對象,提供有關servlet 的信息,如作者、版本等。

destroy()方法

destroy方法在容器移除Servlet時執行,同樣只執行一次。這個方法會在所有的線程的service()方法執行完成或者超時后執行,調用這個方法后,容器不會再調用這個Servlet的方法,也就是說容器不再把請求發送給這個Servlet。這個方法給Servlet釋放占用的資源的機會,通常用來執行一些清理任務。

這個接口定義了初始化一個servlet,服務請求和從容器中移除Servlet的方法。他們按照下面的順序執行:

servlet被實例化后,用init方法進行初始化

◆客戶端的任何請求都調用service方法

Servlet被移除服務,調用destroy方法銷毀
 
servlet的生存周期如下圖:
 
請求分發

請求分發可以讓一個servlet把請求分配到另外一個資源,RequestDispatcher接口提供了實現他的機制。可以通過下面兩種方式從servletContext中獲得一個實現了RequestDispatcher接口的對象:

◆getRequestDispatcher

◆getNamedDispatcher

getRequestDispatcher方法接受一個指向目標資源的URL路徑

RequestDispatcher rd = getservletContext().getRequestDispatcher(“/catalog”);

getNamedDispatcher方法接受一個servlet名稱參數,這個名稱是在部署描述符中﹤servlet-name﹥元素指定的那個名稱。

RequestDispatcher rd = getservletContext().getNamedDispatcher (“catalog”);

RequestDispatcher接口有兩個方法,允許你在調用的servlet完成初步處理后把請求響應分配到另外一個資源,

forward()方法:

public void forward(servletRequest request, servletReponse reponse) throws SwerletException,IOException

forward方法上讓你把請求轉發到另外的servlet或者jsp或者html等資源,由這個資源接下來負責響應。如:

  1. RequestDispatcher rd = getservletContext().getRequestDispatcher(“/catalog”);  
  2. rd. forward(request,response); 

include()方法:

public void include (servletRequest request, servletReponse reponse) throws SwerletException,IOException
include方法讓你的servlet響應中包含另外一個資源生成內容

  1. RequestDispatcher rd = getservletContext().getRequestDispatcher(“/catalog”);  
  2. rd. include(request,response); 

結合WebWork的具體分析

WebWork是由OpenSymphony組織開發實現MVC模式的J2EE Web框架。在介紹完servlet規范的相關內容后,我們看看WebWork是如何注入到一個servlet中的,假設我們有一個上下文環境為“/WebWorkdDemo”的WEB應用。

部署描述符

在部署描述符中,我們需要進行如下配置:

  1. servlet﹥  
  2. servlet-name﹥webwork﹤/servlet-name﹥  
  3. servlet-class﹥com.opensymphony.webwork.dispatcher.servletDispatcher﹤/servlet-class﹥  
  4. ﹤/servlet﹥  
  5. ……  
  6. servlet-mapping﹥  
  7. servlet-name﹥webwork﹤/servlet-name﹥  
  8. ﹤url-pattern﹥*.action﹤/url-pattern﹥  
  9. ﹤/servlet-mapping﹥  

我們聲明了一個名為webworkservlet和*.action到這個servlet的映射,這個servlet就是webwork中的controller,擔任MVC框架中非常重要的控制器角色。

映射請求到servlet在XWork的配置文件xwork.xml中有如下片段:

  1. ﹤action name="demo" class=" webworkapp.DemoAction"﹥  
  2.        ﹤result name="success" type="dispatcher"﹥  
  3.               ﹤param name="location"﹥/demo.jsp﹤/param﹥  
  4.        ﹤/result﹥  
  5. ﹤/action﹥  

這樣我們由http://localhost:8080/WebWorkDemo/demo.action這個URL向服務器發出請求時,WEB容器首先確定轉到哪一個WEB應用程序,容器將請求URL和上下文環境進行匹配后知道將轉到/WebWorkdDemo這個WEB應用。

接下來容器會在/WebWorkdDemo這個應用的部署描述符中進行查找處理這個請求的servlet,根據后綴*.action找到名稱為webwork這個servlet,這樣根據部署描述符,這個請求被映射到webwork中的controller組件com.opensymphony.webwork.dispatcher.servletDispatcher來處理。這個擔任控制器組件的servlet在他的service()方法中在根據請求的路徑解析出對應的action來進行處理。

通過上面的的處理,實現了將web請求轉到了webwork中的控制器servletDispatcher。不止是webwork,實現MVC的web框架都需要進行類似的處理來將web請求轉入到自己的controller.以便進行進一步的處理。

servlet生存周期

servletDispatcher這個servlet的存周期可以如下:

在服務器啟動的時候,容器首先實例化servletDispatcher

實例化完成后,將調用init()方法,在init方法中執行了以下操作:

◆初始化Velocity引擎

◆檢查是否支持配置文件重新載入功能。如果支持,每個request請求都將重新裝載xwork.xml配置文件,在開發時非常方便。

◆設置一些文件上傳的信息,比如:上傳臨時目錄,上傳的***字節等。

每次請求都調用service()方法,在service方法中執行了以下方法

◆通過request請求取得action的命名空間

◆根據servlet請求的Path,解析出要調用該請求的Action的名字(actionName)

◆創建Action上下文(extraContext),遍歷HttpservletRequest、HttpSession、servletContext 中的數據,并將其復制到Webwork的Map實現中,至此之后,所有數據操作均在此Map結構中進行,從而將內部結構與servlet API相分離。

◆以上述信息作為參數,調用ActionProxyFactory創建對應的ActionProxy實例。ActionProxyFactory 將根據Xwork 配置文件(xwork.xml)中的設定,創建ActionProxy實例,ActionProxy中包含了Action的配置信息(包括Action名稱,對應實現類等等)。

◆執行proxy的execute()方法
容器移除servlet 時執行destroy(),在servletDispatcher這個servlet中并沒有重寫destroy方法,在移除servlet時,將什么也不做。

請求分發

WebWork提供了多種活靈活視圖展現方式,例如還是我們上面在xwork.xml中的配置:

  1. ﹤action name="demo" class=" webworkapp.DemoAction"﹥  
  2.        ﹤result name="success" type="dispatcher"﹥  
  3.               ﹤param name="location"﹥/demo.jsp﹤/param﹥  
  4.        ﹤/result﹥  
  5. ﹤/action﹥  

根據以上配置當DemoAction的返回值為"success"時的處理類型為"dispatcher",當result的type為"dispatcher"時,通過javax.servlet.RequestDispatcher的forward()或include()方法將處理結果和表現層融合后展現給用戶
我們可以看看WebWork提供的dispatcher類型Result Type的實現類com.opensymphony .webwork.dispatcher.servletDispatcherResult中的代碼片斷:

  1. HttpservletRequest request = servletActionContext.getRequest();  
  2.  HttpservletResponse response = servletActionContext.getResponse();  
  3.  RequestDispatcher dispatcher = request.getRequestDispatcher(finalLocation);  
  4.  if (dispatcher == null) {  
  5.    response.sendError(404, "result '" + finalLocation + "' not found");     
  6.    return;  
  7.  }  
  8.  if (!response.isCommitted() && (request.getAttribute("javax.servlet.include.servlet_path") == null)) {  
  9.    request.setAttribute("webwork.view_uri", finalLocation);  
  10.    request.setAttribute("webwork.request_uri", request.getRequestURI());  
  11.      
  12.    dispatcher.forward(request, response);  
  13.  } else {  
  14.    dispatcher.include(request, response);  
  15.  }  


servletDispatcherResult類的從servletActionContex中得到HttpservletRequest和HttpservletResponse,然后調用request.getRequestDispatcher(finalLocation)方法得到一個RequestDispatcher實例,如果返回的是null,則輸出404頁面未找到的錯誤,否則將調用dispatcher.forward(request, response)或者dispatcher.include(request, response)進行請求分發,將處理結果和表現層融合后展現給用戶。

結束語

在Servlet中如何添加web框架通過以上的介紹,我們對web框架是如何注入到Servlet中有了簡單的了解,如果想更深入的研究,可以閱讀Servlet規范以及一些成熟框架的源碼。

【編輯推薦】

  1. 什么是Servlet以及常用Servlet API有哪些
  2. JSP Servlet開發最初那點事
  3. Java Servlet API文檔實用說明
  4. 整合Apache中JSP和PHP
  5. Java Servlets(JSP)開發環境
責任編輯:仲衡 來源: IT168
相關推薦

2011-08-02 11:07:00

2010-05-11 16:22:40

2009-07-09 10:03:40

Servlet應用Weblogic環境

2010-04-20 09:14:33

Struts

2009-07-06 10:25:14

Java Web Se

2019-10-09 11:26:01

JavaXMLSQL

2023-09-01 07:21:11

2009-07-07 09:41:02

異步ServletAJAX

2009-07-08 15:13:00

獲取所session數JSPServlet

2019-08-15 10:56:10

WebServletSpring mvc

2011-06-14 17:51:47

QListview Qt MVC

2012-05-11 09:38:00

MVVM Light

2018-05-24 13:58:03

LinuxGoogle Web字Font Finder

2009-05-12 09:54:09

JavaRestCoC

2009-07-09 16:47:26

Servlet的Web

2009-07-09 10:25:05

Servlet的Web

2009-09-27 09:41:21

Web開發

2023-10-22 20:20:37

FiberGo

2013-09-02 09:18:59

2010-07-19 10:16:24

ibmdwWeb2.0
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产免费一区 | 精品欧美一区二区三区精品久久 | 国产视频不卡一区 | 亚洲欧美激情精品一区二区 | 国产激情三区 | 一区二区三区视频在线观看 | 区一区二在线观看 | 6996成人影院网在线播放 | 三级国产三级在线 | 毛片网络| 一级一级毛片免费看 | 欧美精品首页 | 亚洲一区 中文字幕 | 可以免费观看的av片 | 欧美中文视频 | 国产成人高清在线观看 | 每日更新av | 久久精品国产一区二区三区不卡 | 国产精彩视频在线观看 | 99热热| 久久久久久久久国产 | 国产精品免费一区二区三区四区 | 91精品国产91久久综合桃花 | 中文字幕在线一区二区三区 | 91精品国产乱码久久久久久久 | 欧美精品一区二区在线观看 | 国产一区二区在线视频 | 亚洲精品一区二区三区蜜桃久 | 91视频日本 | 最近日韩中文字幕 | 91久久爽久久爽爽久久片 | 精品国产乱码久久久久久蜜退臀 | 99久久精品一区二区成人 | 成人免费淫片aa视频免费 | 久久精品国产99国产精品 | 一区二区三区在线电影 | av在线成人 | 久草资源| 在线免费观看黄色av | 亚洲一区二区在线播放 | 日本一二三区高清 |