如何让token过期

来源:25-5 json web token的认证机制

kanokano

2021-03-16

老师,在一些需要token过期的场景下,比如用户修改密码,用户重新登录,这个时候按照常理来说,之前的那个token应该是要按过期处理的,但是如果用数据库来验证这些状态的话,jwt不就失去了意义吗?请问老师有没有什么比较好的解决方案。

写回答

1回答

bobby

2021-03-17

其实要完美地失效JWT是没办法做到的。

"Actually, JWT serves a different purpose than a session and it is not possible to forcefully delete or invalidate an existing token."
这篇文章写得比较简单易懂:https://medium.com/devgorilla/how-to-log-out-when-using-jwt-a8c7823e8a6

有以下几个方法可以做到失效 JWT token:

    1. 将 token 存入 DB(如 Redis)中,失效则删除;但增加了一个每次校验时候都要先从 DB 中查询 token 是否存在的步骤,而且违背了 JWT 的无状态原则(这不就和 session 一样了么?)。

    2. 维护一个 token 黑名单,失效则加入黑名单中。

    3. 在 JWT 中增加一个版本号字段,失效则改变该版本号。

    4. 在服务端设置加密的 key 时,为每个用户生成唯一的 key,失效则改变该 key


0
0

Go+Python打造电商系统 自研微服务框架 抓紧高薪机遇

快速转型Go工程师,成为具备双语言后端能力的开发者

508 学习 · 530 问题

查看课程