Struts2请求处理的内部流程说明(版本一)
流程說明:
1.客戶端瀏覽器(Client)向服務器發送一個 http 請求(HttpServletRequest)
2.Container(容器) 通過 web.xml 映射請求,并獲得控制器(Controller)的名字
3.Container 調用控制器(StrutsPrepareAndExecuteFilter 或 FilterDispatcher)。在Struts 2.1.3 以前調用 FilterDispatcher,Struts 2.1.3以后調用 StrutsPrepareAndExecuteFilter。
4.Controller 調用 ActionMapper,ActionMapper 返回 ActionMapping 對象。
5.Controller 將請求的控制權委派給 ActionProxy,并把請求數據傳給 ActionProxy
6.ActionProxy 調用配置管理器(ConfigurationManager) 讀取配置文件的信息(struts.xml)
7.ActionProxy 拿到 Action、Interceptor等相關數據后,調用 ActionInvocation,并把 Action、Interceptor 等相關數據及請求數據傳遞給 ActionInvocation。
8.ActionInvocation 調用前置攔截器,把 request 請求里面的參數封裝到 ActionContext 對象中的 ValueStack 對象中的值棧對象里面。
如果 Action 的屬性名與 ValueStack 對象中的值棧對象的屬性名相同(即與 request 請求里的參數相同),則將 ValueStack 對象中的值棧對象的屬性值賦給對應的 Action 屬性。
9.根據 Action 的配置信息,調用 Result 組件。
11.Result 信息返回給 ActionInvocation。將結果信息封裝到 HttpServletResponse 對象中
12.容器將 HttpServletResponse 對象中信息打成響應數據包發送給客戶端。
有疑問:
聽說特定請求映射到特定 Action的相關信息存儲在 ActionMapping 對象中,這就奇怪了,確定執行哪個 Action 不是由 ConfigurationManager 干的嗎?如果 ActionMapper 就確定了哪個 Action,那后面調 ConfigurationManager 讀取配置文件豈不是多余了?
ActionMapping 對象中剛開始時是空的,ConfigurationManager 對象去解析 struts.xml 后,將請求與 Action 的映射關系封裝到 ActionMapping 對象中。
總結
以上是生活随笔為你收集整理的Struts2请求处理的内部流程说明(版本一)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JDBC 示意图
- 下一篇: (在DDOS攻击中通过)