拦截器配置,获取请求头中的用户id,放置到ThreadLocal线程空间中

@Component
public class AppTokenInterceptor extends HandlerInterceptorAdapter {

    /**
     * 前置拦截 -  获取请求头中的  userId , 放入到当前线程中
     *
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //1. 获取请求头
        String userId = request.getHeader("userId");
        if (StringUtils.isNotBlank(userId) && !StringUtils.equals("0",userId)) {
            //2. 存入线程
            ApUser apUser = new ApUser();
            apUser.setId(Long.valueOf(userId));

            AppThreadLocalUtil.setUser(apUser);
        }

        return super.preHandle(request, response, handler);
    }

    /**
     * 清楚线程中的用户数据
     *
     * @param request
     * @param response
     * @param handler
     * @param modelAndView
     * @throws Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        //清楚线程数据
        AppThreadLocalUtil.clear();
        super.postHandle(request, response, handler, modelAndView);
    }
}

注入拦截器对象

ackage com.ligong.search.config;

import com.ligong.search.interceptor.AppTokenInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WmMvcConfig implements WebMvcConfigurer {

    @Autowired
    private AppTokenInterceptor appTokenInterceptor;

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(appTokenInterceptor).addPathPatterns("/api/**");
    }
}
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
拦截使用 `ThreadLocal` 存储数据时,需要注意以下几点: 1. `ThreadLocal` 的作用域是线程级别的,即同一个线的所有代码都可以访问该 `ThreadLocal` 对象存储的数据,但不同线程之间是互不干扰的。 2. 在拦截,如果使用 `ThreadLocal` 存储数据,需要在请求处理结束后将其清空,否则该线程在下一次请求时可能会访问到上一次请求存储的数据。 3. 在控制访问 `ThreadLocal` 存储的数据时,需要确保在同一个线,否则会出现获取到 `null` 的情况。 以下是一个示例代码: ```java public class MyInterceptor implements HandlerInterceptor { private static final ThreadLocal<String> threadLocal = new ThreadLocal<>(); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String value = // 获取需要存储的数据 threadLocal.set(value); return true; } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { threadLocal.remove(); // 清空 ThreadLocal 的数据 } } @RestController public class MyController { @GetMapping("/test") public String test() { String value = MyInterceptor.threadLocal.get(); return "value: " + value; } } ``` 在上面的代码,`MyInterceptor` 使用 `ThreadLocal` 存储数据,`MyController` 通过访问 `MyInterceptor.threadLocal` 获取存储的数据。请注意,`MyInterceptor.threadLocal` 是一个静态变量,因此在不同的线访问到的是不同的 `ThreadLocal` 对象。如果在 `MyController` 访问时获取到的是 `null`,那么很可能是因为在不同的线访问了 `ThreadLocal` 对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Code攻城狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值