SpringBoot配置拦截器

1.创建一个自定义拦截器,实现HandlerInterceptor

复制代码
package com.hmdp.utils;
import com.hmdp.dto.UserDTO;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
/**
 * 拦截器
 */
public class LoginInterceptor implements HandlerInterceptor {
    /**
     * 前置拦截器 --- 进入controller之前进行登录校验
     *
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //1.获取session
        HttpSession session = request.getSession();
        //2.获取session中的用户
        Object user = session.getAttribute("user");
        //3.判断用户是否存在
        if (user==null){
            //4.不存在,拦截 返回401未授权
            response.setStatus(401);
            return false;
        }
        //5.存在,保存用户到ThreadLocal
        UserHolder.saveUser((UserDTO) user);
        //6.放行
        return true;
    }
    /**
     * 增强拦截器--空过
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
    }
    /**
     *  后置拦截器 --- 用户业务执行完毕,销毁对应的用户信息
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        UserHolder.removeUser();
    }
}
复制代码

2.调用配置类拦截器

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
package com.hmdp.config;
import com.hmdp.utils.LoginInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;<br>
<strong>@Configuration</strong>
public class MvcConfig <strong>implements WebMvcConfigurer</strong> {
 
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //添加拦截器,、
        //配置不拦截的路径
        registry.addInterceptor(<strong>new LoginInterceptor()</strong>).excludePathPatterns(
                "/user/code",
                "/user/login",
                "/blog.hot",
                "/shop/**",
                "/shop-type/**",
                "/voucher/**"
        );
    }
}

  

posted @   Timeouting  阅读(926)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
历史上的今天:
2020-03-30 dispatcher配置
2020-03-30 Filter链执行顺序
2020-03-30 Filter在放行请求前后对response操作导致页面输出差异的剖析
点击右上角即可分享
微信分享提示