-
自定義攔截器方式一:實現Interceptor接口查看全部
-
攔截器棧查看全部
-
攔截器查看全部
-
相關代碼——(下): @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)&&".".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"; } } }查看全部
-
添加struts配置文件和jar包:右擊工程名----MyEclipse----Add Struts Capp...--------選擇版本-----next------再回去配置一下Struts.xml文件 下面是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"/>-->查看全部
-
Struts2內置常用的攔截器: 1.params攔截器: -負責將請求參數設置為Action屬性 2.staticParams攔截器: -將配置文件中action元素的子元素param參數設置為Action屬性 3.servletConfig攔截器: -將源于Servlet API的各種對象注入到Action,必須實現對應接口 4.fileUpload攔截器: -對文件上傳提供支持,將文件和元素設置到對應的Action屬性,實際上內部依然使用了Commons-FileUpload組件。 5.exception攔截器: -捕獲異常,并且將異常映射到用戶自定義的錯誤頁面 6.validation攔截器: -調用驗證框架進行數據驗證 更多的攔截器可在struts核心包的struts-default.xml中查看查看全部
-
1.定義攔截器 1.1.創建一個攔截器類繼承自AbstractInterceptor類 1.2.實現intercept方法 eg: public String intercept(ActionInvocation invocation) throws Exception { //1.執行action之前 long start=System.currentTimeMillis(); //2.執行下一個攔截器,如果是最后一個攔截器,則執行目標action String result=invocation.invoke(); //3.執行action之后 long end=System.currentTimeMillis(); //4.花費的時間 long time=end-start; System.out.println("執行花費的時間: "+time+" ms"); return result; } 2.配置攔截器 <interceptors> <interceptor name="timeinterceptor" class="com.imooc.interceptor.TimerInterceptor"></interceptor> </interceptors> 3.引用攔截器 <interceptor-ref name="timeinterceptor"></interceptor-ref>查看全部
-
實現計算Action的執行時間實例的步驟查看全部
-
自定義攔截器: 1.方法一:實現Interceptor接口 -void init():初始化攔截器所需資源 -void destroy() :釋放在init()中分配的資源 -String intercept(ActionInvocation ai)throws Exception 實現攔截器功能,利用ActionInvocation參數獲取Action狀態,返回result字符串作為邏輯視圖。 2.方式二:繼承AbstractInterceptor類 -提供了init()和destroy() 方法的空實現 -只需要實現intercept方法即可 實際開發當中一般會去繼承AbstractInterceptor這個父類查看全部
-
攔截器: Struts2大多數核心功能是通過攔截器實現的,每個攔截器完成某項功能。 攔截器方法在Action執行之前或者之后執行。 攔截器棧: 從結構上看,攔截器棧相當于多個攔截器的組合。 在功能上看,攔截器棧也是攔截器。 攔截器的執行過程是一個遞歸的過程,工作原理類似于過濾器。查看全部
-
客戶端通過httpservletrequest向servlet容器,也就是tomcat提交一個請求,這個請求會經過一些列的過濾器,如ActionContentClearUp過濾器,最終被struts核心過濾器過濾,也就是FilterDispatcher.從struts2.1.3版本以后struts的核心控制器發生了變化,變成了PrepqreAndExecuteFiletr,核心過濾器過濾以后,調用訪問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流程查看全部
-
攔截器查看全部
舉報
0/150
提交
取消