91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Struts2工作原理的示例分析

發布時間:2021-09-14 09:27:53 來源:億速云 閱讀:102 作者:小新 欄目:編程語言

這篇文章主要介紹Struts2工作原理的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

一、工作原理

在Struts2框架中的處理大概分為以下幾個步驟

      1 客戶端初始化一個指向Servlet容器(例如Tomcat)的請求

      2 這個請求經過一系列的過濾器(Filter)(這些過濾器中有一個叫做ActionContextCleanUp的可選過濾器,這個過濾器對于Struts2和其他框架的集成很有幫助,例如:SiteMesh Plugin)

      3 接著FilterDispatcher被調用,FilterDispatcher詢問ActionMapper來決定這個請是否需要調用某個Action

      4 如果ActionMapper決定需要調用某個Action,FilterDispatcher把請求的處理交給ActionProxy

      5 ActionProxy通過Configuration Manager詢問框架的配置文件,找到需要調用的Action類

      6 ActionProxy創建一個ActionInvocation的實例。

      7 ActionInvocation實例使用命名模式來調用,在調用Action的過程前后,涉及到相關攔截器(Intercepter)的調用。

      8 一旦Action執行完畢,ActionInvocation負責根據struts.xml中的配置找到對應的返回結果。返回結果通常是(但不總是,也可 能是另外的一個Action鏈)一個需要被表示的JSP或者FreeMarker的模版。在表示的過程中可以使用Struts2 框架中繼承的標簽。在這個過程中需要涉及到ActionMapper

二 工作流程

      1、客戶端瀏覽器發出HTTP請求.

      2、根據web.xml配置,該請求被FilterDispatcher接收

      3、根據struts.xml配置,找到需要調用的Action類和方法, 并通過IoC方式,將值注入給Aciton

      4、Action調用業務邏輯組件處理業務邏輯,這一步包含表單驗證。

      5、Action執行完畢,根據struts.xml中的配置找到對應的返回結果result,并跳轉到相應頁面

      6、返回HTTP響應到客戶端瀏覽器

三、攔截器和過濾器的區別

      1、攔截器是基于java反射機制的,而過濾器是基于函數回調的。

      2、過濾器依賴于servlet容器,而攔截器不依賴于servlet容器。

      3、攔截器只能對Action請求起作用,而過濾器則可以對幾乎所有請求起作用。

      4、攔截器可以訪問Action上下文、值棧里的對象,而過濾器不能。

      5、在Action的生命周期中,攔截器可以多次調用,而過濾器只能在容器初始化時被調用一次。

四、什么要使用Struts2

Struts2 是一個相當強大的Java Web開源框架,是一個基于POJO的Action的MVC Web框架。它基于當年的Webwork和XWork框架,繼承其優點,同時做了相當的改進。

     1、Struts2基于MVC架構,框架結構清晰,開發流程一目了然,開發人員可以很好的掌控開發的過程。

     2、使用OGNL進行參數傳遞。

     OGNL提供了在Struts2里訪問各種作用域中的數據的簡單方式,你可以方便的獲取Request,Attribute,Application,Session,Parameters中的數據。大大簡化了開發人員在獲取這些數據時的代碼量。

     3、強大的攔截器

     Struts2 的攔截器是一個Action級別的AOP,Struts2中的許多特性都是通過攔截器來實現的,例如異常處理,文件上傳,驗證等。攔截器是可配置與重用的,可以將一些通用的功能如:登錄驗證,權限驗證等置于攔截器中以完成一些Java Web項目中比較通用的功能。在我實現的的一Web項目中,就是使用Struts2的攔截器來完成了系統中的權限驗證功能。

     4、易于測試

     Struts2的Action都是簡單的POJO,這樣可以方便的對Struts2的Action編寫測試用例,大大方便了5Java Web項目的測試。

     易于擴展的插件機制在Struts2添加擴展是一件愉快而輕松的事情,只需要將所需要的Jar包放到WEB-INF/lib文件夾中,在struts.xml中作一些簡單的設置就可以實現擴展。

     6、模塊化管理

     Struts2已經把模塊化作為了體系架構中的基本思想,可以通過三種方法來將應用程序模塊化:將配置信息拆分成多個文件把自包含的應用模塊創建為插件創建新的框架特性,即將與特定應用無關的新功能組織成插件,以添加到多個應用中去。

     7、全局結果與聲明式異常

     為應用程序添加全局的Result,和在配置文件中對異常進行處理,這樣當處理過程中出現指定異常時,可以跳轉到特定頁面。

     他的如此之多的優點,是很多人比較的青睞,與spring ,Hibernate進行結合,組成了現在比較流行的ssh框架,當然每個公司都要自己的框架,也是ssh變異的產品。

五、看到網友的對Struts2的原理總結,我自己也總結以便后續的面試,以下是我的疑問

1、客服端發起一個請求,通過HTTP協議指向Tomcat容器,tomcat拿到請求她干了什么?

2、我們web.xml配置

<filter>

<filter-name>struts2</filter-name>

<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>

</filter>

<filter-mapping>

<filter-name>struts2</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>

我們從web配置文件中可以看到org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter,這個Filter這個類有什么用?

這個 /* 是攔截所有的請求,他攔截了請求做了什么處理? <url-pattern>/*</url-pattern>

3、我們struts.xml配置

<struts>

<package name="default" namespace="/" extends="struts-default">

<action name="hello">

<result>

/Hello.jsp

</result>

</action>

</package>

</struts>

誰負責根據struts.xml配置,找到需要調用的Action類和方法呢?

4、最后根據struts.xml中的配置找到對應的返回結果result,在返回HTTP響應到客戶端瀏覽器

   struts2的工作原理

  • 客戶端發送請求

  • 經過一系列的過濾器

  • FilterDispatcher通過ActionMapper來決定這個REquest需要調用的Action

  • FilterDispather交給ActionProxy

  • 通過ConfigurationManager詢問struts.xml找到對應的Action

  • ActionProxy創建一個ActionInvocation實例

  • 調用Action Action執行完畢ActionInvocation負責根據struts.xml中的配置找到對應的返回結果

Struts攔截器,常用的攔截器

  • Struts2的攔截器是其核心部分,它提供了一種機制,可以定義一個特殊的模塊,對請求進行封裝和處理,這個模塊在Action執行前后都可以進行

  • modelDriven(模型驅動) servletConfig(獲取ServletApo) params(動態參數注入) validation(輸入驗證 聲明式驗證)

struts2的優點

  • 實現了mvc模式 層次結構清晰,

  • 豐富的標簽庫,提高了開發效率

  • 提供了豐富的攔截器實現

  • 方便異常處理

  • 通過配置文件可以掌握系統各個部分之間的關系

struts2核心控制器

  • FilterDispatcher

  • 它負責攔截所有的用戶請求,當 用戶請求到達時,該Filter會過濾用戶請求。如果用戶請求以action結尾,該請求將被轉入Struts 2框架處理。

struts2配置文件覆蓋順序

  • struts.xml -> struts.properties -> web.xml(配置過濾器時,指定參數。程序員可以編寫)

struts2修改常量的方式

  • struts.xml : <constant name="struts.action.extension" value="do"/>

  • struts.properties : struts.action.extension=do

Action

  • Action為多例的,所以在Spring中Scope要設置參數

  • 通配符 動態調用

Action實現的三種方式

  • 單純的POJO

  • 實現Action接口 (提供了格式化的返回參數)

  • 繼承ActionSupport(實現了Action接口并且其中還做了一些國際化和驗證的功能)

訪問ServletAPI

  • ServletActionContext

  • 實現接口 ServletRequestAware,ServletResponseAware ,ServletContextAware 攔截器負責注入(ServletConfig)

結果視圖

  • chain(轉發到動作,要是不在同一個包內需要設置 name) dispatcher(默認) redierct (請求重定向) stream(文件上傳和下載)

默認的struts-default有什么作用

  • struts-default包是由struts內置的,它定義了struts2內部的眾多攔截器和Result類型,而Struts2很多核心的功能都是通過這些內置的攔截器實現,當包繼承了struts-default包才能使用struts2為我們提供的這些功能。

  • 通常每個包都應該繼承struts-default包。

struts2如何對指定的方法進行驗證

  • 驗證功能是由validation攔截器來負責處理的。回顯錯誤信息是由workflow攔截器來負責處理的。

  • 驗證失敗以后錯誤信息回顯需要設置 <result name="input">/regist.jsp</result> 結果視圖

  • 對類中所有方法進行驗證,復寫validate()方法,當出錯的時候addFieldError("name", "請輸入用戶名");

  • 對指定方法:將validate()方法改寫成為public void validateDemo1 后面是指定方法的名字(驗證Demo1方法)

值棧

  • ValueStack的生命周期為Action的生命周期,保存在request域中,

  • 每個action都有與之對應的值棧,action對象默認保存在棧頂

  • 使用OGNL訪問值棧中的內容不需要添加# 而訪問其他域中的需要添加#

ActionContext、ServletContext、pageContext的區別?

  • ActionContext是當前Action的上下文環境,通過ActionContext可以獲取到request、session、ServletContext等與Action有關的對象的引用

  • ServletContext是域對象,一個web應用中只有一個ServletContext,生命周期伴隨整個web應用;

  • pageContext是JSP中的最重要的一個內置對象,可以通過pageContext獲取其他域對象的應用,同時它是一個域對象,作用范圍只針對當前頁面

攔截器

  • 每個攔截器都是實現了Interceptor接口的java類

  • Init() 在這個攔截器初始化的時候被調用

  • intercept() 當攔截器起作用的時候調用

  • destroy() 在攔截器被銷毀的時候調用

  • struts2默認有18個攔截器

自定義攔截器

  • 編寫一個類繼承 MethodFilterInterceptor

  • struts2.xml中聲明攔截器

  • struts2.xml中聲配置攔截器 , 當指定自定義攔截器時默認攔截器會失效,所以還要顯示的在指定一次.

文件上傳

  • file域 form表單 enctype=multipart/form-data 提交方式為post

  • action接受文件對象為表單中的name, 文件類型為name+ContentType 文件名字為:jsp頁面file組件的名稱+FileName

  • 可以用數組來接收多個文件的上傳

以上是“Struts2工作原理的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙岩市| 茂名市| 卢龙县| 阳曲县| 方城县| 万年县| 吉木乃县| 八宿县| 平武县| 吴忠市| 罗江县| 岗巴县| 达孜县| 竹溪县| 溧阳市| 兴义市| 内黄县| 清镇市| 井冈山市| 文登市| 称多县| 牡丹江市| 桃江县| 巴中市| 舟曲县| 喀什市| 察隅县| 南漳县| 马鞍山市| 睢宁县| 寻甸| 曲水县| 绥化市| 林甸县| 福贡县| 胶南市| 英吉沙县| 云安县| 和龙市| 石家庄市| 桂林市|