StrutsPrepareAndExecuteFilter和FilterDispatcher的區別比較
FilterDispatcher是早期struts2的過濾器,如 2.1.3 以前的版本,後期的都用StrutsPrepareAndExecuteFilter了,如 2.1.六、2.1.8。
StrutsPrepareAndExecuteFilter名字已經很能說明問題了:
一、prepare與execute,前者表示準備,能夠說是指filter中的init方法,即配製的導入;
二、prepare與execute,後者表示進行過濾,指doFilter方法,即將request請求,轉發給對應的 action去處理。
FilterDispatcher是struts2.0.x到2.1.2版本的核心過濾器.! StrutsPrepareAndExecuteFilter是自2.1.3開始就替代了FilterDispatcher的!
--這樣的改革固然是有好處的,爲何這麼說? 應該知道若是咱們本身定義過濾器的話, 是要放在strtus2的過濾器以前的, 若是放在struts2過濾器以後,你本身的過濾器對action的過濾做用就廢了,不會有效!除非你是訪問jsp/html!
那我如今有需求, 我必須使用Action的環境,而又想在執行action以前拿filter作一些事, 用FilterDispatcher是作不到的!
那麼StrutsPrepareAndExecuteFilter能夠把他拆分紅StrutsPrepareFilter和StrutsExecuteFilter,能夠在這兩個過濾器之間加上咱們本身的過濾器!
--打個比喻, 如今有病人要作手術, 如今struts2要作兩件事, 搭病牀(環境),執行手術! 那麼打麻藥的工做呢.? 不可能要病人站着打吧, 因此必須有病牀的環境,打完麻藥以後再動手術! 這個比喻很是形象了!
從Struts2.1.3開始,將廢棄ActionContextCleanUp過濾器,而在StrutsPrepareAndExecuteFilter過濾器中包含相應的功能。
三個初始化參數:
一、config參數:指定要加載的配置文件。逗號分割。
二、actionPackages參數:指定Action類所在的包空間。逗號分割。
三、configProviders參數:自定義配置文件提供者,須要實現ConfigurationProvider接口類。逗號分割。
<filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> <init-param> <param-name>actionPackages</param-name> <param-value>com.cjm.web.action</param-value> </init-param> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
最後,若是程序報類找不到異常,且後面有 org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter等信息,多是你的版本問題.解決方法是肯定你的struts版本,若是是2.1.3以前的版本,用 org.apache.struts2.dispatcher.FilterDispatcher,之後的版本則配置org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter。
struts2-流程詳解-StrutsPrepareAndExecuteFilter
http://hi.baidu.com/liangzhongbo/item/07be3a560c16bc13da163536
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
初始化:
public void init(FilterConfig filterConfig)
throws ServletException
{
InitOperations init = new InitOperations();
FilterHostConfig config = new FilterHostConfig(filterConfig);
init.initLogging(config);
Dispatcher dispatcher = init.initDispatcher(config);
init.initStaticContentLoader(config, dispatcher);
prepare = new PrepareOperations(filterConfig.getServletContext(), dispatcher);
execute = new ExecuteOperations(filterConfig.getServletContext(), dispatcher);
excludedPatterns = init.buildExcludedPatternsList(dispatcher);
postInit(dispatcher, filterConfig);
init.cleanup();
break MISSING_BLOCK_LABEL_108;
Exception exception;
exception;
init.cleanup();
throw exception;
}
執行任務
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
throws IOException, ServletException
{
HttpServletRequest request;
HttpServletResponse response;
request = (HttpServletRequest)req;
response = (HttpServletResponse)res;
prepare.setEncodingAndLocale(request, response);
/*爲當前線程建立ActionContext,ActionContext是ThreadLocal的,ActionContent其實就是一個線程安全的HashMap,它內部使用一個HashMap
來儲存相關信息,這個map的構造是使用dispatcher.createContextMap(request, response, null, servletContext)來造成的,這個
map包括的信息有session,request,response,ServletContext,RequestMap,SessionMap等各類信息,能夠通
個這個ActionContent取得各類信息,例如ActionContext.getContext().getSession()來得到當前的Session,
若是要得到request或者response必須用ServletActionContext它是ActionContent的子類,提供更多的方法,如
果是forward那也會新建一個新的ActionContent,這個新的ActionContent直接使用舊的ActionContent的數據來
構造*/
prepare.createActionContext(request, response);prepare.assignDispatcherToThread();if(excludedPatterns != null && prepare.isUrlExcluded(request, excludedPatterns)){chain.doFilter(request, response);} else{request = prepare.wrapRequest(request);org.apache.struts2.dispatcher.mapper.ActionMapping mapping = prepare.findActionMapping(request, response, true);if(mapping == null){boolean handled = execute.executeStaticResourceRequest(request, response);if(!handled)chain.doFilter(request, response);} else{execute.executeAction(request, response, mapping);}}prepare.cleanupRequest(request);break MISSING_BLOCK_LABEL_178;Exception exception;exception;prepare.cleanupRequest(request);throw exception;}