-
自定義攔截器---實現interceptor接口查看全部
-
攔截器工作原理 注:類似于web中的過濾器,遞歸調用查看全部
-
客戶端通過httpservletrequest向servlet容器,也就是tomcat提交一個請求,這個請求會經過一些列的過濾器,如ActionContentClearUp過濾器,最終被struts核心過濾器過濾,也就是FilterDispatcher.從struts2.1.3版本以后struts的核心控制器發生了變化,變成了StrutsPrepareAndExecuteFilter,核心過濾器過濾以后,調用訪問ActionMapping,決定是否調用某一action,如果用戶請求的是jsp頁面或者是其他資源,不會調用某一action,如果決定調用某一action,ActionMapping會將控制權委派給ActionProxy,也叫action代理,此時action代理會通過一個Configuration Manager也就是配置管理器對象加載struts核心配置文件,也就是struts.xml.如果在struts.xml找到需要創建的action,ActionProxy會創建一個Action Invocation實例,action Invocation包括一些列的攔截器和action,先順序執行一些列的攔截器,然后執行action處理,返回一個結果,通過result返回一個視圖或者調用另外某個action.當返回這個視圖以后,將之前執行過的攔截器反向執行一遍,然后通過response響應客戶端的請求. struts的執行流程: 1用戶發送請求到服務器,服務器通過ActionMapper執行一系列的過濾器,其中包括struts的核心過濾器StrutsPrepareAndExecuteFilter 2.ActionProxy(Action代理)通過ConfigurationManager(配置管理器)加載struts的核心配置文件struts.xml,找到需要調用的action返回給action代理 3.然后執行Action Invocation,其中包含一個或者多個攔截器,依次執行,然后才是執行Action,Action返回一個結果決定跳轉到哪個視圖或者是action(result的type屬性決定)。然后依次反向執行攔截器,之后將結果反饋給用戶查看全部
-
默認攔截器棧查看全部
-
Strut2架構剖析查看全部
-
下面是4個開發模式常用配置的簡介--- <!-- 開啟使用開發模式,詳細錯誤提示 --> <!-- <constant name="struts.devMode" value="true"/>--> <!-- 指定每次請求到達,重新加載資源文件 --> <!-- <constant name="struts.i18n.reload" value="true"/>--> <!-- 指定每次配置文件更改后,自動重新加載 --> <!-- <constant name="struts.configuration.xml.reload" value="true"/>--> <!-- 指定XSLT Result使用樣式表緩存 --> <!-- <constant name="struts.xslt.nocache" value="true"/>-->查看全部
-
定義一個攔截器查看全部
-
自定義攔截器方式:1、實現Interceptor接口 2、繼承AbstractInterceptor類查看全部
-
struts2核心架構查看全部
-
相關代碼——(下): @login.jsp 信息:${session_error} <form action="Login" method="post"><!-- 默認情況下:Login.action或Login都行。 --> 用戶名:<input name="user" type="text" /> 密碼:<input name="pwd" type="password" /> <input value="Login" type="submit" /> </form> @manager.jsp 后臺管理頁面。只有已登錄的用戶才能訪問!查看全部
-
相關代碼——(中): @struts.xml <struts> <package name="default" extends="struts-default" namespace="/"> <!-- 注冊攔截器 --> <!-- Ps:攔截器棧內的攔截器(除了默認攔截器)的name要與攔截器棧外的攔截器要一致,因為引用攔截器棧的時候,里面的攔截器是從外面的攔截器中的class引用的 --> <interceptors> <interceptor name="AuthI" class="com.imooc.interceptor.AuthInterceptor"></interceptor> <!-- 自定義攔截器mystack:組合了defaultStack和AuthI --> <interceptor-stack name="mystack"> <interceptor-ref name="defaultStack"></interceptor-ref> <interceptor-ref name="AuthI"></interceptor-ref> </interceptor-stack> </interceptors> <!-- 通過此Action訪問后臺管理頁面,需要判斷用戶是否已登錄,如果未登錄則跳轉到登錄頁面 --> <action name="Auth"> <result>/WEB-INF/page/manager.jsp</result> <result name="login">/login.jsp</result> <!-- 引用自定義的攔截器 --> <interceptor-ref name="mystack"></interceptor-ref> </action> <action name="Login" class="com.imooc.action.LoginAction" method="login"> <result>/WEB-INF/page/manager.jsp</result> <result name="error">/login.jsp</result> </action> </package> </struts>查看全部
-
相關代碼——(上): @LoginAction.java public class LoginAction extends ActionSupport implements SessionAware{ private String user; private String pwd; private Map<String,Object> session; public void setSession(Map<String, Object> session) { this.session=session; } // setter/getter... public String login(){ if("admin".equals(user)&&"admin".equals(pwd)){ session.put("session_user", user); return SUCCESS; }else{ session.put("session_error", "用戶名或密碼不正確!"); return ERROR; } } } @AuthInterceptor.java public class AuthInterceptor extends AbstractInterceptor { @Override public String intercept(ActionInvocation invocation) throws Exception { ActionContext context=ActionContext.getContext(); Map<String , Object> session=context.getSession(); if(session.get("session_user")!=null){ String result=invocation.invoke(); return result; }else{ return "login"; } } }查看全部
-
下面是4個開發模式常用配置的簡介--- <!-- 開啟使用開發模式,詳細錯誤提示 --> <!-- <constant name="struts.devMode" value="true"/>--> <!-- 指定每次請求到達,重新加載資源文件 --> <!-- <constant name="struts.i18n.reload" value="true"/>--> <!-- 指定每次配置文件更改后,自動重新加載 --> <!-- <constant name="struts.configuration.xml.reload" value="true"/>--> <!-- 指定XSLT Result使用樣式表緩存 --> <!-- <constant name="struts.xslt.nocache" value="true"/>-->查看全部
-
默認攔截器棧: <!-- 為Action顯示引用攔截器后,默認的攔截器defaultStack不再生效,需要手工引用。而且從順序角度去講,最好把默認的攔截器寫在自定義攔截器上面 --> <interceptor-ref name="defaultStack"></interceptor-ref>查看全部
-
Struts2內置常用的攔截器: 1.params攔截器: -負責將請求參數設置為Action屬性 2.staticParams攔截器: -將配置文件中action元素的子元素param參數設置為Action屬性 3.servletConfig攔截器: -將源于Servlet API的各種對象注入到Action,必須實現對應接口 4.fileUpload攔截器: -對文件上傳提供支持,將文件和元素設置到對應的Action屬性,實際上內部依然使用了Commons-FileUpload組件。 5.exception攔截器: -捕獲異常,并且將異常映射到用戶自定義的錯誤頁面 6.validation攔截器: -調用驗證框架進行數據驗證 更多的攔截器可在struts2-core包的struts-default.xml中查看查看全部
舉報
0/150
提交
取消