1、isdangerous包
questions: itsdangerous用来解决什么问题,为什么需要用到itsdangerous?
安全的加密解密:
1、使用没有逆运算的公式,只能加密不能解密。
2、可逆,能加密解密。保证安全性——私钥。
itsdangerous内部默认使用了HMAC和SHA1来签名,基于 Django 签名模块。它也支持JSON Web 签名 (JWS)。
itsdangerous模块的参考资料链接 https://itsdangerous.readthedocs.io/en/1.1.x/
eg:
from itsdangerous.jws import TimedJSONWebSignatureSerializer
from django.conf import settings
def dumps(json,expires):
"""
将字典加密,返回加密字符串
:param json: 字典
:return: 字符串
"""
serializer = TimedJSONWebSignatureSerializer(settings.SECRET_KEY,expires)
json_str = serializer.dumps(json).decode()
return json_str
def loads(json_str,expires):
"""
将加密字符串解密
:param json_str: 加密字符串
:return: 字典
"""
serializer = TimedJSONWebSignatureSerializer(settings.SECRET_KEY, expires)
try:
json = serializer.loads(json_str)
except:
return None
else:
return json