UserThreadLocal 用户线程Token拦截验证

注册拦截器

package com.tanhua.server.config;import com.tanhua.server.interceptor.RedisCacheInterceptor;
import com.tanhua.server.interceptor.UserTokenInterceptor;
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 WebConfig implements WebMvcConfigurer {/*** redis 缓存检测*/@Autowiredprivate RedisCacheInterceptor redisCacheInterceptor;/*** token检测*/@Autowiredprivate UserTokenInterceptor userTokenInterceptor;/*** 过滤器链 根据顺序拦截** @param registry 注册过滤器链 根据顺序拦截*/@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(this.userTokenInterceptor).addPathPatterns("/**");registry.addInterceptor(this.redisCacheInterceptor).addPathPatterns("/**");}
}

编写用户线程工具类

package com.tanhua.common.utils;import com.tanhua.common.pojo.User;/*** 当前用户线程*/
public class UserThreadLocal {private UserThreadLocal() {}private static final ThreadLocal<User> LOCAL = new ThreadLocal<>();/*** 将user放到threadLocal** @param user user*/public static void setUser(User user) {LOCAL.set(user);}/*** 返回当前线程中的user对象** @return 返回当前线程中的user对象*/public static User getUser() {return LOCAL.get();}/*** 删除当前线程中的user对象*/public static void remove() {LOCAL.remove();}
}
定义标记不需要验证token 的注解
package com.tanhua.common.utils;import java.lang.annotation.*;/*** 标记不需要验证token 的方法*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented //标记注解
public @interface NoAuthorization {
}

拦截器

package com.tanhua.server.interceptor;import com.tanhua.common.pojo.User;
import com.tanhua.common.utils.NoAuthorization;
import com.tanhua.common.utils.UserThreadLocal;
import com.tanhua.server.service.UserService;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;/*** 拦截 效验token*/
@Component
public class UserTokenInterceptor implements HandlerInterceptor {@Autowiredprivate UserService userService;//将user对象放入threadLocal@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//效验handler 是否为匹配到controller的方法if (!(handler instanceof HandlerMethod)) {return true;}//判断方法是否包含了NoAuthorization注解, 标记不需要验证TOKENif (((HandlerMethod) handler).hasMethodAnnotation(NoAuthorization.class)) {return true;}//获取请求keyString token = request.getHeader("Authorization");if (StringUtils.isNotEmpty(token)) {//调用sso  验证 token 的有效性User user = userService.queryUserByToken(token);if (null != user) {UserThreadLocal.setUser(user);return true;}}//token 无效  401无权限response.setStatus(401);return false;}//完成方法:从threadLocal中删除user对象@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {UserThreadLocal.remove();}
}

定义过滤器。 注册获取器。 拦截到请求。如果命中controller的方法, 判断该方法@NoAuthorization 有没有使用自定义注解标记。不需要token拦截。如果没有就拦截。拿到请求token  验证token 。如果token合法 

UserThreadLocal.setUser(user); 将用户信息。放到ThreadLocal用户线程。

在service 中。就那可以拿到user用户信息了。不用每个service 方法都校验一次token 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/442696.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jsonwebtoken jwt token 简单加密

<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.9.1</version> </dependency> //生成tokenMap<String, Object> claims new HashMap<String, Object>();claims.put(&q…

RelativeDateFormat时间计算工具类

import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date;/*** 时间计算工具类*/ public class RelativeDateFormat {private static final long ONE_MINUTE 60000L;private static final long ONE_HOUR 3600000L;private static final …

随机名字生成小demo源码

根据提供的文字随机生成指定字符的名称&#xff0c;挺简单的&#xff0c;一个小demo吧 源字符 package com.example.demo;import cn.hutool.core.util.RandomUtil;import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.F…

silence丶你的名字

/*** 自媒体文章自动审核服务** author silence丶你的名字* createTime 2021-08-22-17:57*/ Service Log4j2 public class WemediaNewsAutoScanServiceImpl implements WemediaNewsAutoScanService {/*** fastServer 地址*/Value("${fdfs.url}")private String fileS…

java.security.invalidkeyexception: illegal key size or default parameters

解决原文摘自&#xff1a;Java实现AES加密,异常java.security.InvalidKeyException: Illegal key size 的解决_走过的足迹-CSDN博客Java实现AES加密&#xff0c;抛出异常如下&#xff1a;java.security.InvalidKeyException: Illegal key size代码参考 http://my.oschina.net/J…

Caused by: org.springframework.boot.web.server.PortInUseException: Port 8081 is already in use 端口占用

Caused by: org.springframework.boot.web.server.PortInUseException: Port 8081 is already in use 解决引用&#xff1a; 在dos下&#xff0c;输入 netstat -ano|findstr 8080 //说明&#xff1a;查看占用8080端口的进程 显示占用端口的进程 taskkill /pid 9476 …

Linux+Docker+腾讯云/阿里云服务器 安装MySQL相关命令整理

注&#xff1a;主要是收集整理一些常用的命令 主要参考&#xff1a;狂神说docker以及其他的一些命令收集。主要是因为平常安装的mysql外部无法访问 MYSQL的创建用户&#xff0c;授权用户&#xff0c;删除用户&#xff0c;查看用户_ZJE-CSDN博客_mysql 显示用户1.查看用户2.创…

list.size为1但是内容为null

又是一件离奇的事被我遇到了&#xff0c;哈哈。测试环境暴露出来的问题。还奇怪了好一会儿。然后查了一下资料。原来很多人都遇到了。大概原因就是 sql语句使用了计算函数sum(),但是where条件出来的数据为空&#xff0c;最后返回到java 映射进list了。 造成了list.size为1但是内…

遍历这些字符串,如果字符串没有包含数字的,就将字符串中的小写字母转成大写字母并打印字符串

package cn.silence;public class StrDemo3 {/*** 有如下字符串:"12ab","java","cd","Server78"* //遍历这些字符串&#xff0c;如果字符串没有包含数字的&#xff0c;就将字符串中的小写字母转成大写字母并打印字符串*/public static…

idea springboot一直卡在启动 没有日志输出

断点从 springApplication.run(args)&#xff0c;进入 在 SpringApplication&#xff0c;322行 handleRunFailure(context, ex, exceptionReporters, listeners); 可以看到错误信息。 修改后正常启动

40029错误{“errcode“:40029,“errmsg“:“invalid code, rid: 623bbdcd-3c97f4af-5a2c06d6“}

背景&#xff1a;服务器获取微信小程序openid的时候&#xff0c;报code无效。 但是code是根据开发者文档生成的。服务器配置也没有问题。 因为服务器&#xff0c;wechatAppId 和 wechatSecret不一致&#xff0c;会分别报这两个的错误。 最终检查为&#xff0c;生成code的APP…

CORS error 状态码451

项目背景&#xff0c;测试环境的前端代码&#xff0c;指向本地开发机。访问451 谷歌浏览器 查询错误码猜测&#xff0c;可能是跨域问题。其实具体错误也不是特别清楚。就想着换个浏览器。 换搜狗浏览器。问题解决了。记录一下

javassist将类的类型修改,将接口修改为类

将接口interface 修改为class 接口 接口字节码 修改为class类后的字节码 将接口修改成为了&#xff0c;class类 但是这里还有一个坑&#xff0c;是class 没有默认构造&#xff0c;需要添加一个无参构造&#xff0c;不然不能实例化对象 这是生成构造方法后的字节码&#xff0c;…

根据字节码获取类的绝对路径

适用于当前模块或引入模块。 不适用于第三方jar包 /*** 根据字节码获取类绝对路径** param clazz clazz* return classRealPath*/private static String getClassRealPath(Class<?> clazz) {String classPath clazz.getName().replace(".", "/") …

Javassist给方法添加形参,给方法添加参数

前言&#xff1a; 此次用到的jar包 Javassist 此篇博文不是教大家怎么去了解他&#xff0c;因为我也不是很了解 主要是因为这两天有一个需求是扩展knife4j 需要用到大量反射了解到的。 因为这方面资料太少了。我也是慢慢摸索出来的。把这些发出来吧。 我理解的 Javassist 主…

javassist动态给方法添加注解,动态给形参添加注解,动态给类添加注解

参考文档 这个写的挺全的&#xff0c;就是写的有点丑 javassist教程_不懂人情世故的博客-CSDN博客_java javassist转载 https://www.cnblogs.com/rickiyang/p/11336268.htmljavassist使用全解析Java 字节码以二进制的形式存储在 .class 文件中&#xff0c;每一个 .class 文件包…

解决javassist不能重复加载字节码的问题

因为我的是一个接口&#xff0c;所以麻烦诸多。 事实上在类加载前做好准备工作&#xff0c;不会遇到这个问题&#xff0c;但是我正巧&#xff0c;在使用javassist的时候需要加载类&#xff0c;因为我要读取源码&#xff0c;拿到注释&#xff0c;再通过ssit 修改字节码&#xf…

根据type类型判断是否为基本数据类型,或基本数据类型的包装类,或泛型为基本数据类型

根据type类型判断是否为基本数据类型&#xff0c;或基本数据类型的包装类&#xff0c;或泛型为基本数据类型 /*** 判断是否为基本数据类型&#xff0c;或基本数据类型的包装类&#xff0c;或泛型为基本数据类型* string true* int true* Integer true* String[] true* user[] …

根据参数类型,获取泛型里所有的引用clazz,获取泛型实际参数

/*** 根据参数类型&#xff0c;获取泛型里所有的引用clazz* 列&#xff1a; public List<PageResult<List<User>>> intTest(RequestEntity<Map<String, List<PageResult<User>>>> req)** aClass class org.springframework.http.Re…