flask 实现token机制

生成token

用token校验身份,是前后端交互的常用方式。
它有以下特性:

  • 会失效
  • 加密
  • 可以根据它拿到用户的信息
生成方式:
# 依赖导包:
import jwt
from flask import current_app


def  generate_token(payload, expiry):
    key = current_app.config.get('SECRET_KEY')

    if 'expiry' not in payload:
        payload['expiry'] = expiry
    try:
        token = jwt.encode(payload, key, algorithm='HS256')
        return token
    except Exception as e:
        print('获取token报错信息e', e)
        return e
token的校验:
def check_token(token):
    """验证token"""
    key = current_app.config.get('SECRET_KEY')
    payload = jwt.decode(token, key, algorithms='HS256')
    return payload
生成一个刷新的token
def _generate_token(payload, is_refresh=True):
    """生成token"""
    # 设置有效期
    expiry = datetime.now() + timedelta(seconds=30)
    token = generate_token(payload, str(expiry))
    # 默认需要刷新生成token
    if is_refresh:
        # 刷新生成的token, 有效期15天
        expiry = datetime.now() + timedelta(days=15)
        # 给payload 添加刷新token的标识
        payload['is_refresh'] = True
        refresh_token = generate_token(payload, expiry)
    else:
        refresh_token = None
    return token, refresh_token

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值