前言
JWT 是 json web token 的缩写, token的作用你应该已经了解,用于识别用户身份避免每次请求都需要验证
用来解决前后端分离时的用户身份验证
在传统的web项目中 我们会在form表单中设置隐藏字段来提交token信息
但是在前后端分离时,我们就无法像网页一样直接放在表单里,
需要前后端的配合才能完成token的验证
下面是使用itsdangerous模块实现JWT的生成与解析
time
Serializer
# 用一个值作为密钥 当然你可以用任何的字符串作为密钥 越复杂越安全
# 除去密钥外 再添加一个盐值来提高安全性
# 控制token的有效时长 默认为3600秒
# 实例化对应的对象传入两个参数,一个空的token就产生了,但是我们要用token来识别用户身份
# 你当然可以把token和用户的身份信息存到数据库做对应
# 但是jwt已经考虑到了,所以你只需要在dump中添加用于识别用户身份的数据即可
# 后期当用户请求到达时,使用同样的方法反解就能获取到token中包含的数据
# 从而完成用户身份的识别
salt_str,)
# 获取token并在其中写入用户的身份信息
# s.dump() # 将token写入指定文件 与json的dump意思相同
# 得到最后的token数据 分返回类型为字节 所以做一个解码
# iat字段来自官方文档 用于表示token的过期时间,用于客户端做判断,不是必须的
# 另外两个字段是自己定义的
dumps({
time(),
# 得到token 在用户登录成功时返回给客户端
token)
# 客户端利用任何手段来存储token值,在请求数据时带上token一起请求
# =======================================================================
# 当客户端带上token来请求时我们需要从中获取用户的身份信息
# 解析token时可能会发生异常,常见的如token过期,或token被篡改等等..
# 服务器需要做相应的检查