Springboot 拦截器实战:请求处理流程解析

版权申诉
0 下载量 177 浏览量 更新于2024-07-02 收藏 454KB DOCX 举报
该文档是关于在Spring Boot中使用拦截器(Interceptor)进行请求处理的演示,通过一个具体的配置类和拦截器实现示例来阐述如何设置和使用拦截器。 在Spring Boot应用中,拦截器是一种强大的工具,可以用于在请求被实际处理之前或之后执行特定的操作,例如权限验证、日志记录、性能统计等。这里,我们看到一个名为`WebConfiguration`的配置类,它实现了`WebMvcConfigurer`接口。这个接口提供了自定义Spring MVC行为的灵活性,其中包括注册拦截器。 ```java 1 @Configuration 2 public class WebConfiguration implements WebMvcConfigurer { 3 4 @Override 5 public void addInterceptors(InterceptorRegistry registry) { 6 registry.addInterceptor(new TstCfg()); 7 } 8 } ``` 在这个配置类中,`addInterceptors`方法被覆盖,用于向拦截器注册表`InterceptorRegistry`添加自定义的拦截器`TstCfg`。这样,每当有请求匹配到由`TstCfg`处理的URL时,拦截器就会介入。 接下来,我们看下`TstCfg`这个拦截器的实现: ```java 11 public class TstCfg extends HandlerInterceptorAdapter { 12 13 @Override 14 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { 16 System.out.println("前"); 17 return super.preHandle(request, response, handler); 18 } 19 20 @Override 21 public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { 22 System.out.println("后"); 23 } 24 25 @Override 26 public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { 27 // ... 28 } 29 } ``` `TstCfg`继承自`HandlerInterceptorAdapter`,这是一个抽象的拦截器类,提供了默认的空实现。我们关注其中的三个关键方法: 1. `preHandle`:在请求被处理器处理之前调用。在这个方法中,你可以进行一些预处理工作,比如检查用户权限、记录请求信息等。如果`preHandle`返回`false`,则请求处理将被中断;如果返回`true`,请求将继续被处理器处理。在这里,我们只是简单打印了一个字符串"前",并调用了父类的`preHandle`方法。 2. `postHandle`:在请求处理完成后,但在视图被渲染之前调用。这个方法适合进行数据加工或者清理工作,但不会影响请求的后续流程。同样,这里也只是简单打印了"后"。 3. `afterCompletion`:在视图渲染完成,整个请求完全处理完毕后调用。这个方法可以用来做一些资源释放、日志记录等收尾工作。在示例中,这个方法没有具体实现,可以根据实际需求填充代码。 通过Spring Boot的拦截器机制,我们可以定制化地处理HTTP请求,增加应用的功能性和灵活性。这个例子展示了如何创建一个简单的拦截器,以及如何在Spring Boot的配置中注册它,以便在请求生命周期的不同阶段执行自定义逻辑。