springboot拦截器创建

创建了一个实现了HandlerInterceptor接口的拦截器类,用于在目标方法执行前后进行操作,如在preHandle中进行登录检查。如果用户未登录,则重定向到登录页面。在WebMvcConfigurer的实现类中注册了拦截器,设置拦截所有请求并排除特定的放行路径,如登录和静态资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 创建拦截器类实现于接口HandlerInterceptor,实现三个相关方法

  • preHandle 目标方法执行前

  • postHandle 目标方法执行后

  • afterCompletion 目标网页渲染完成后

  @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        //获取请求路径
        String requestURI = request.getRequestURI();
        log.info("拦截的请求路径是{}",requestURI);
        //登录检查逻辑
        HttpSession session = request.getSession();
        Object loginUser = session.getAttribute("loginUser");
        if (loginUser != null){
            return true;
        }else {
            request.setAttribute("msg","请登录");
            request.getRequestDispatcher("/").forward(request,response);
            return false;
        }

    }
  1. 拦截器添注册到容器

  • addPathPatterns+拦截路径

  • excludePathPatterns+放行路径

@Configuration
public class AdminWebConfing implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new LoginINterfcerter())
                .addPathPatterns("/**")//拦截所有请求,包括静态请求
                .excludePathPatterns("/","/login","/css/**","/fonts/**","/images/**","/js/**");//放行的请求
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值