初学SpringBoot的小白,计划着先实现功能,再尝试着理解原理,不对之处,还望斧正,不胜感激。
1,自定义一个拦截器非常简单,只需要实现HandlerInterceptor这个接口即可,该接口有三个方法可以实现,
1),preHandle()方法:该方法会在控制器前执行,返回值为布尔值,true时表示放行,false拦截。
2),postHandle()方法:该方法会在控制器方法调用之后,且解析视图之前执行。可以通过此方法对,请求域中的模型和视图做出进一步的修改。
3),afterCompletion()方法:该方法会在整个请求完成,即视图渲染结束之后执行。可以通过此方法,实现一些资源清理、记录日志信息等工作。
2,代码实现。
package ink.awz.config;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Calendar;
/**
* @version 1.0
* @Author:杨杰
* @Date:2021/10/11 15:02
*/
public class Interceptor implements HandlerInterceptor {
private static final Logger logger =
LoggerFactory.getLogger(Interceptor.class);
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse
response, Object handler) throws Exception {
logger.info("执行请求前");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse
response, Object handler, ModelAndView modelAndView) throws Exception {
logger.info("执行完一次请求");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse
response, Object handler, Exception ex) throws Exception {
logger.info("整个请求都处理完咯,DispatcherServlet也渲染了对应的视图咯,此时我可以做一些清理的工作了");
}
}
package ink.awz.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
/**
* @version 1.0
* @Author:杨杰
* @Date:2022/2/24 15:19
*/
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new Interceptor()).addPathPatterns("/user");
}
}
项目目录