1、安装itsdangerous模块
pip install itsdangerous
2、在视图类中导入itsdangerous模块和异常处理
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
from itsdangerous import SignatureExpired # 异常
3、创建TimedJSONWebSignatureSerializer 对象
# settings.SECRET_KEY:django自带的密钥, 需要导入settings.py
# 3600:超时时间,单位秒
serializer = Serializer(settings.SECRET_KEY, 3600)
# 要加密的信息
info = {'confirm':user.id}
# 加密
token = serializer.dumps(info) # 加密后的返回值是bytes类型
# 转码
token = token.decode()
4、解密
# 还是需要TimedJSONWebSignatureSerializer 对象
serializer = Serializer(settings.SECRET_KEY, 3600)
# 将加密过的信息解密,但是可能加密的信息已经超时,所以这里我们需要加个异常,如果超时后该怎么做
try:
info = serializer.loads(token)
# 获取解密后的信息
user_id = info['conirm']
except SignatureExpired as e:
# 发生异常后的处理
pass