- 31
- 0
问题描述
SpringSecurity通过用户名和密码进行认证后,返回的是JWT的token,token的有效期设置的为15min,但是我如何去刷新token,如果token不进行刷新那么15min以后就会过期
问题出现的环境背景及自己尝试过哪些方法
每次请求我都会去查看是否能够获得认证信息,如果能够获得认证信息,我会针对认证信息重新生成一次token,放到返回头中去,这样也就要求前端每次请求后需要从返回头中获取token去更新token,后面有了解到refresh token,但是不知道在JWT中该如何去弄,因为认证的信息是放在token中的,如果token过期了,我需要重新生成token,但是前端如何知道何时更细token
相关代码
主要是思路流程问题,不涉及到具体代码
你期待的结果是什么?实际看到的错误信息又是什么?
前端请求登录后,后端发给一个token和refresh token,然后后端根据这两个自己去更新token,前端只需要保证附带上这两个就可以了。期望中是这样的,按照我的理解token应该存在服务器。在Spring Security Oauth2中返回access token时也是存在token和refresh token,Spring Security Oauth2是如何实现刷新令牌的
- 共 0 条
- 全部回答
-
蝌蚪小尾巴 普通会员 1楼
在Spring Security中,如果你想要在token过期后自动刷新token,你可以使用以下的配置:
首先,你需要在
application.properties或application.yml文件中配置jwt.timeToLive和jwt algorithms。jwt.timeToLive设置token的过期时间,jwt algorithms设置需要使用的JWT算法。properties jwt.timeToLive=3600 jwt.algorithms=HS256然后,你需要在
web.xml文件中配置spring.security.token复活计数器。这个配置可以帮助你决定在哪个时间点,如果token被重置或者丢失,服务器会主动发送一个刷新令牌。xml <bean id="token复活计数器" class="org.springframework.security.crypto.jwt.JwtToken复活计数器"> <property name="maxDuration" value="3600" /> <property name="functivedates" value="3600" /> </bean>最后,你需要在你的业务逻辑中,使用
@PreAuthorize注解来判断用户是否已经登录。如果用户还没有登录,你可以在这个注解后添加一个逻辑,生成一个新token,并在数据库中保存。java @PreAuthorize("hasRole('USER')") @PostMapping("/user/login") public ResponseEntity<?> login(@RequestBody User user) { // 检查用户是否已经登录 // 如果已经登录,生成新的token并返回 // 如果还没有登录,返回401错误 }在这个例子中,如果用户还没有登录,新的token会自动刷新。但是,这只是一个基本的例子,实际使用中你可能需要根据你的具体需求来调整这个配置。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
