md5生成、解密token

1、定义的携带字符串,导包:

import time
from django.core import signing
import hashlib
from django.core.cache import cache
from django.conf import settings
settings.configure(DEBUG=True)

HEADER = {'typ': 'JWP', 'alg': 'default'}
KEY = 'CHEN_FENG_YAO'
SALT = 'www.lanou3g.com'
TIME_OUT = 30 * 60  # 30min

2、生成:

def encrypt(obj):
    """加密"""
    value = signing.dumps(obj, key=KEY, salt=SALT)
    value = signing.b64_encode(value.encode()).decode()
    return value

def create_token(username):
    """生成token信息"""
    # 1. 加密头信息
    header = encrypt(HEADER)

    # 2. 构造Payload
    payload = {"username": username, "iat": time.time()}
    payload = encrypt(payload)

    # 3. 生成签名
    md5 = hashlib.md5()
    md5.update(("%s.%s" % (header, payload)).encode())
    signature = md5.hexdigest()  # 加密方式

    token = "%s.%s.%s" % (header, payload, signature) # 使用'.'链接

    # 存储到缓存中redis中
    cache.set(username, token, TIME_OUT)
    return token

3、解析:

def decrypt(src):
    """解密"""
    src = signing.b64_decode(src.encode()).decode()
    raw = signing.loads(src, key=KEY, salt=SALT)
    return raw

def get_payload(token):
    """获取用户加密的payload, 以'.'切割token, payload位于列表1号位"""
    payload = str(token).split('.')[1]
    payload = decrypt(payload)
    return payload

def get_username(token):
    payload = get_payload(token)
    return payload['username']

4、验证token:

def check_token(token):
    username = get_username(token)
    last_token = cache.get(username) # 从redis中获取用户名对应的token
    if last_token:
        return last_token == token
    return False

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值