Django中用itsdangerous模块加密

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值