目标:在springboot项目里配置自定义springmvc拦截器
步骤:
1.编写拦截器
1)创建一个类MyInterceptor
2)实现HandlerInterceptor接口
3)实现接口里的三个方法
①:preHandle()
②:postHandle()
③:afterCompletion()
4)类的完整代码
package com.example.springbootdemo.myInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import lombok.extern.slf4j.Slf4j;
@Slf4j
//springmvc拦截器
public class MyInterceptor implements HandlerInterceptor {
@Override
//在业务处理器处理请求之前被调用。预处 理,可以进行编码、安全控制、权限校验等处理;
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
log.debug("这是拦截器的preHandle");
return true;
}
@Override
//在业务处理器处理请求执行完成后,生成视图之前执行。后处理(调用了Service并返回ModelAndView,但未进行页面渲染),有机会修改ModelAndView (这个博主就基本不怎么用了);
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
log.debug("这是拦截器的postHandle");
}
@Override
在DispatcherServlet完全处理完请求后被调用,可用于清理资源等。返回处理(已经渲染了页面);
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
throws Exception {
log.debug("这是拦截器的afterCompletion");
}
}
2.编写配置类实现WebMvcConfigurer,在该类中添加各种组件(此时我添加配置拦截器)
1)创建MvcConfig配置类
2)实现WebMvcConfigurer接口
3)注册拦截器
//注册拦截器
@Bean
public MyInterceptor myInterceptor() {
return new MyInterceptor();
}
4)添加拦截器到springmvc拦截器链
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(myInterceptor()).addPathPatterns("/**/*hello");
}
5)完整代码
package com.example.springbootdemo.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import com.example.springbootdemo.myInterceptor.MyInterceptor;
//设置为配置类
@Configuration
public class MvcConfig implements WebMvcConfigurer {
//注册拦截器
@Bean
public MyInterceptor myInterceptor() {
return new MyInterceptor();
}
//添加拦截器到springmvc拦截器链
@Override
public void addInterceptors(InterceptorRegistry registry) {
//指定拦截的路径 基于ant风格
registry.addInterceptor(myInterceptor()).addPathPatterns("/**/*hello");
}
}
3.测试
在application.properties里配置日志的优先级
#日志记录级别
logging.level.com.example.springbootdemo=debug
logging.level.springframework=info