java自定义拦截器 HandlerInterceptorAdapter或HandlerInterceptor的使用

Spring拦截器  

  HandlerInterceptorAdapter需要继承,

  HandlerInterceptor需要实现  

  可以作为日志记录和登录校验来使用
  建议使用HandlerInterceptorAdapter,因为可以按需进行方法的覆盖。

主要为3种方法:

  preHandle:拦截于请求刚进入时,进行判断,需要boolean返回值,如果返回true将继续执行,如果返回false,将不进行执行。一般用于登录校验。
  postHandle:拦截于方法成功返回后,视图渲染前,可以对modelAndView进行操作。
  afterCompletion:拦截于方法成功返回后,视图渲染前,可以进行成功返回的日志记录。

springmvc的配置xml

<!-- 拦截器配置,拦截顺序:先执行后定义的,排在第一位的最后执行。 -->
<mvc:interceptors>
    <!-- 可配置多个-->
    <mvc:interceptor>
        <!-- mapping path 表示 需要拦截的url-->
        <mvc:mapping path="${adminPath}/**" />
        <!-- exclude-mapping path 表示 需要排除拦截的url-->
        <mvc:exclude-mapping path="${adminPath}/" />
        <mvc:exclude-mapping path="${adminPath}/login" />
        <!-- bean 表示拦截器的类-->
        <bean class="org.jasig.cas.web.interceptor.LogInterceptor" />
    </mvc:interceptor>
</mvc:interceptors>

springboot的注解配置

@Configuration
public class InterceptorConfig implements WebMvcConfigurer {

    private static final Logger logger =  LoggerFactory.getLogger(InterceptorConfig.class);

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(authenticationInterceptor())
                .addPathPatterns("/**");
        registry.addInterceptor(loginInterceptor())
                .addPathPatterns("/**")
                .excludePathPatterns("/css/**","/images/**","/js/**","/login.html");
        // 拦截所有请求,通过判断是否有 @LoginRequired 注解 决定是否需要登录或者通过excludePathPatterns配置不需要拦截的路径
        //多拦截器配置
    }

 

posted @ 2020-04-19 15:06  九涯  阅读(1655)  评论(0编辑  收藏  举报