struts的常用配置以及自定義攔截器
Web.xml中的配置
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher><!-- -->
<dispatcher>FORWARD</dispatcher>
2、struts自定義攔截器:
第一步:建立一個了類整合Struts中的 MethodFilterInterceptor
整合這個類的好處:
1、只需要重寫一個方法
2、可以設定過濾哪個action不攔截
public class BOSLogininterceptor extends MethodFilterInterceptor {
@Override
protected String doIntercept(ActionInvocation invocation) throws Exception {
// User user = (User) ServletActionContext.getRequest().getSession().getAttribute(“user”);
ActionProxy proxy = invocation.getProxy();
String actionName = proxy.getActionName(); //請求的地址
String namespace = proxy.getNamespace();
User user = BOSUtils.getUser();
if(user == null) {
//沒有登入,跳轉到登入的頁面
return "login";
}else {
//登入了放行
return invocation.invoke();
}
}
}
第二步:在Spring的Application中配置自定義過濾器
<!-- 配置登入的攔截器 -->
<interceptors>
<interceptor name="bosLogininterceptor" class="com.puya.bos.web.interceptor.BOSLogininterceptor">
<!-- 放行不攔截的方法-->
<param name="excludeMethods">login</param>
</interceptor>
<!-- 定義一個攔截器棧,將自己的定義的攔截器新增進去,同時也將struts2的預設的攔截器棧也新增進去 -->
<interceptor-stack name="myStack">
<interceptor-ref name="bosLogininterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 將自定義的攔截器棧設定成預設的攔截器棧 -->
<default-interceptor-ref name="myStack"></default-interceptor-ref>
<!-- 全域性結果集定義 -->
<global-results>
<result name="login">/login.jsp</result>
</global-results>
<!-- 需要進行許可權控制的頁面訪問 -->
<action name="page_*_*">
<result type="dispatcher">/WEB-INF/pages/{1}/{2}.jsp</result>
</action>
<!-- 採用註解建立物件,類名就是簡單類名的小寫 -->
<action name="userAction_*" class="userActions" method="{1}">
<result name="home">/index.jsp</result>
</action>
</package>
相關文章
- HandlerInterceptor - 自定義攔截器
- Dubbo自定義日誌攔截器
- day13-自定義攔截器
- flume自定義攔截器遇到的問題
- Flume內建攔截器與自定義攔截器(程式碼實戰)
- Spring MVC 中的攔截器的使用“攔截器基本配置” 和 “攔截器高階配置”SpringMVC
- spring boot 新增自定義監聽器、過濾器、攔截器Spring Boot過濾器
- SpringBoot自定義攔截器實現IP白名單功能Spring Boot
- 自定義攔截器,攔截到了某個請求就返回給前端一個JSON串前端JSON
- 短視訊開發app,webservice自定義加入攔截器APPWeb
- 我自定義的攔截器為什麼會靠後執行?
- Struts2 原始碼分析-----攔截器原始碼解析 --- ParametersInterceptor原始碼
- spring mvc攔截器,spring攔截器以及AOP切面的區別和原始碼SpringMVC原始碼
- Spring 常用的三種攔截器詳解Spring
- SpringMVC攔截器,設定不攔截的URLSpringMVC
- Spring Cloud Feign 自定義配置(重試、攔截與錯誤碼處理) 實踐SpringCloud
- SpringMVC攔截器SpringMVC
- axios 攔截器iOS
- spring攔截器Spring
- axios攔截器iOS
- sql攔截器SQL
- Mybatis 攔截器MyBatis
- MyBatis攔截器MyBatis
- SpringBoot 2.X配置登入攔截器Spring Boot
- SpringMVC中的攔截器SpringMVC
- grpc中的攔截器RPC
- Django 常用的自定義裝飾器Django
- Java Filter過濾器(攔截路徑的配置+攔截方式的配置+生命週期+多個過濾器的先後執行順序)JavaFilter過濾器
- Mybatis Interceptor 攔截器MyBatis
- spring boot 攔截器Spring Boot
- SpringMVC-攔截器SpringMVC
- gRPC(3):攔截器RPC
- 【SpringMVC】 4.3 攔截器SpringMVC
- ArkWeb頁面攔截與自定義響應 - 控制載入過程Web
- spring mvc 攔截器的使用SpringMVC
- webwork的攔截器真是好用Web
- Java實現的攔截器Java
- 攔截器的使用問題