struts2核心工作原理
上圖來源於Struts2官方站點,是Struts 2 的整體結構。
一個請求在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
在上述過程中所有的物件(Action,Results,Interceptors,等)都是通過ObjectFactory來建立的。
相關文章
- Struts2工作原理
- Struts2工作原理(圖解)圖解
- .NET與java的MVC模式:struts2核心工作流程與原理JavaMVC模式
- Struts2 原始碼分析-----工作原理分析原始碼
- struts2的工作原理與檔案結構
- Struts2核心元件元件
- 一文讀懂git核心工作原理Git
- JVMTI Agent 工作原理及核心原始碼分析JVM原始碼
- Struts1、Struts2、Hibernate、Spring框架工作原理介紹Spring框架
- Struts2原理詳解
- struts2的工作流程
- struts2中struts.xml和web.xml檔案解析及工作原理XMLWeb
- 深入分析Struts2工作流程
- Struts2攔截器實現原理
- Socket 核心原理分享
- Netty核心原理Netty
- require工作原理UI
- Mybatis工作原理MyBatis
- Nginx工作原理Nginx
- Handler 工作原理
- rman工作原理
- mydumper工作原理
- pr工作原理
- 揭祕Facebook 廣告系統核心演算法Pacing工作原理 (含案例)演算法
- binder核心原理解析
- springboot核心原理Spring Boot
- NameServer 核心原理解析Server
- kafka核心原理總結Kafka
- GeoHash核心原理解析
- javascript引擎工作原理JavaScript
- ZStack基本工作原理
- Mirror 的工作原理
- Web Scraper工作原理Web
- HTTPS工作原理HTTP
- SpringMVC工作原理SpringMVC
- Spark的工作原理Spark
- Docker 工作原理分析Docker
- panic/recover工作原理