十一、springboot WebMvcConfigurer与HandlerInterceptorAdapter使用

springboot WebMvcConfigurer与HandlerInterceptorAdapter使用

简介

WebMvcConfigurer:拦截器的注册类
HandlerInterceptorAdapter:拦截组件

拦截组件HandlerInterceptorAdapter可以有多个,需要注册到WebMvcConfigurer里面,在WebMvcConfigurer里面拦截器是按顺序执行的。

  • 在Spring Boot 2.0后都是靠重写WebMvcConfigurer的方法来添加自定义拦截器,消息转换器等。
  • 在SpringBoot2.0及Spring 5.0前,该类WebMvcConfigurerAdapter被标记为@Deprecated,已被废弃。

WebMvcConfigurer的作用

修饰符和类型方法描述
default voidaddArgumentResolvers(java.util.List resolvers)添加解析器以支持自定义控制器方法参数类型。
default voidaddCorsMappings(CorsRegistry registry)配置跨源请求处理。
default voidaddFormatters(FormatterRegistry registry)添加Converters和Formatters除了默认注册的那些。
default voidaddInterceptors(InterceptorRegistry registry)添加Spring MVC生命周期拦截器,用于控制器方法调用的预处理和后处理。
default voidaddResourceHandlers(ResourceHandlerRegistry registry)添加处理程序以提供静态资源,例如来自Web应用程序根目录下的特定位置的图像,js和css文件,类路径等。
default voidaddReturnValueHandlers(java.util.List handlers)添加处理程序以支持自定义控制器方法返回值类型。
default voidaddViewControllers(ViewControllerRegistry registry)配置预配置了响应状态代码的简单自动控制器和/或视图以呈现响应主体。
default voidconfigureAsyncSupport(AsyncSupportConfigurer configurer)配置异步请求处理选项。
default voidconfigureContentNegotiation(ContentNegotiationConfigurer configurer)配置内容协商选项。
default voidconfigureDefaultServletHandling(DefaultServletHandlerConfigurer configurer)配置处理程序以通过转发到Servlet容器的“默认”servlet来委派未处理的请求。
default voidconfigureHandlerExceptionResolvers(java.util.List resolvers)配置异常解析器。
default voidconfigureMessageConverters(java.util.List<HttpMessageConverter<?>> converters)配置HttpMessageConverters用于读取或写入请求或响应的正文。
default voidconfigurePathMatch(PathMatchConfigurer configurer)帮助配置HandlerMappings路径匹配选项,例如尾部斜杠匹配,后缀注册,路径匹配器和路径助手。
default voidconfigureViewResolvers(ViewResolverRegistry registry)配置视图解析器以将从控制器返回的基于字符串的视图名称转换为具体View 实现以执行渲染。
default voidextendHandlerExceptionResolvers(java.util.List resolvers)扩展或修改默认配置的异常解析器列表。
default voidextendMessageConverters(java.util.List<HttpMessageConverter<?>> converters)用于在配置转换器列表后扩展或修改转换器列表的挂钩。
default MessageCodesResolvergetMessageCodesResolver()提供MessageCodesResolver用于根据数据绑定和验证错误代码构建消息代码的自定义。
default ValidatorgetValidator()提供自定义Validator而不是默认创建的自定义。

准备工作

1.创建一个WebMvcConfig类
package com.honghh.bootfirst.config;


import com.honghh.bootfirst.interceptor.AccessSignAuthInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import javax.annotation.Resource;

/**
 * MVC配置
 *
 * @author honghh
 * @date 2018/8/7 23:01
 */
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
    @Resource
    private AccessSignAuthInterceptor accessSignAuthInterceptor;

    /**
     * Description :
     * Group :
     * <p>
     * 实现自定义拦截器只需要3步
     * 1、创建我们自己的拦截器类并实现 HandlerInterceptor 接口。
     * 2、创建一个Java类继承WebMvcConfigurerAdapter,并重写 addInterceptors 方法。
     * 3、实例化我们自定义的拦截器,然后将对像手动添加到拦截器链中(在addInterceptors方法中添加)。
     *
     * @param registry
     * @author honghh
     * @date 2019/3/22 0022 10:08
     * @author honghh
     * @date 2018/8/13 13:56
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        InterceptorRegistration registration = registry.addInterceptor(accessSignAuthInterceptor);
        // 拦截配置
        registration.addPathPatterns("/api/**");
        // 排除配置
        registration.excludePathPatterns("/api/word");
    }
}

2.创建一个ApiController
package com.honghh.bootfirst.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * ClassName: ApiController
 * Description:
 *
 * @author honghh
 * @date 2019/03/22 9:36
 */
@RestController
@RequestMapping("api")
public class ApiController {

    @RequestMapping("hello")
    public String hello() {
        return "Hello Spring Boot!";
    }

    @RequestMapping("word")
    public String word() {
        return "Hello word!";
    }
}

3.定义一个AccessSignAuthInterceptor类
package com.honghh.bootfirst.interceptor;

import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * description:
 *
 * @author: hh
 * @date: 2018/8/13 11:03
 */
@Slf4j
@Component
public class AccessSignAuthInterceptor extends HandlerInterceptorAdapter {

    /**
     * 只有返回true才会继续向下执行,返回false取消当前请求
     *
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     * @author honghh
     * @date 2018/8/13 13:58
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        log.info("preHandle:请求前调用");
        String url = request.getRequestURI();
        log.info("请求url:{}",url);
        //返回 false 则请求中断
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request,
                           HttpServletResponse response, Object handler,
                           ModelAndView modelAndView) throws Exception {
        log.info("postHandle:请求后调用");
    }

    @Override
    public void afterCompletion(HttpServletRequest request,
                                HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        log.info("afterCompletion:请求调用完成后回调方法,即在视图渲染完成后回调");
    }
}

4.启动项目分别对api/hello,api/word发起请求

返回结果

该项目是基于上一节 十、springboot注解式AOP(@Aspect)统一日志管理 实现。主要添加了以上几个类,获取源码增加上即可。

代码获取

https://gitee.com/honghh/boot-demo.git [boot-aspect]

参考文献

https://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/web/servlet/config/annotation/WebMvcConfigurer.html

  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
HandlerInterceptorAdapter是Spring框架提供的一个适配器类,用于简化自定义拦截器的实现。它实现了HandlerInterceptor接口,并提供了一些默认的空实现方法,方便我们只关注需要实现的方法。 HandlerInterceptor是Spring框架提供的拦截器接口,用于在请求处理过程中进行拦截和处理。通过实现HandlerInterceptor接口,我们可以在请求到达Controller之前、Controller处理过程中以及Controller返回响应之后执行一些自定义的逻辑。 使用HandlerInterceptorAdapterHandlerInterceptor的步骤如下: 1. 创建一个类并实现HandlerInterceptor接口,或者继承HandlerInterceptorAdapter类。 2. 实现需要的方法,常用的方法包括preHandle、postHandle和afterCompletion。 - preHandle方法在请求到达Controller之前执行,可以进行一些前置处理,如权限验证、日志记录等。 - postHandle方法在Controller处理完请求后执行,可以对返回结果进行处理或修改。 - afterCompletion方法在整个请求完成后执行,可以进行一些清理工作,如资源释放等。 3. 在Spring配置文件中配置拦截器。 - 如果使用HandlerInterceptorAdapter,可以通过继承WebMvcConfigurerAdapter类并重写addInterceptors方法来添加拦截器。 - 如果使用HandlerInterceptor,可以通过实现WebMvcConfigurer接口并重写addInterceptors方法来添加拦截器。 注意:在配置拦截器时,需要注意拦截器的顺序,以及拦截的路径和排除的路径的配置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值