0401自学web后端之——认证

认证(Authentication)基础概念

简单来说,目前流行的认证方式有HTTP basic auth和OAuth,其中前者没有后者安全性高,后者使用Token进行认证,而Token的一种流行规范是JWT(Json Web Token)
JWT格式:
在这里插入图片描述
最终格式形如:

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJsb2dnZWRJbkFzIjoiYWRtaW4iLCJpYXQiOjE0MjI3Nzk2Mzh9.gzSraSYS8EXBxLN_oWnFSRgCzcmJmMjLiuyu5CSpyHI

参考:

  1. 阮一峰JSON Web Token 入门教程 https://www.ruanyifeng.com/blog/2018/07/json_web_token-tutorial.html
  2. OAuth、Token、JWT三者之间的关系 https://www.jianshu.com/p/9f80be6ba2e9
  3. https://blog.youkuaiyun.com/gdp12315_gu/article/details/79905424
  4. https://www.jianshu.com/p/537b356d34c9
  5. https://segmentfault.com/a/1190000010312468
  6. https://www.jianshu.com/p/50ade6f2e4fd

相关Python包

>>> from itsdangerous import JSONWebSignatureSerializer
>>> s = JSONWebSignatureSerializer("secret")
>>> encoded = s.dumps({'some': 'payload'})
>>> s.loads(encoded)
{'some': 'payload'}
>>> import jwt
>>> encoded = jwt.encode({'some': 'payload'}, 'secret', algorithm='HS512')
>>> encoded
>>> b'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzUxMiJ9.eyJzb21lIjoicGF5bG9hZCJ9.EgMnzcJYrElON09Bw_OwaqR_Z7Cq30n7cgTZGJqtK1YHfG1cGnGJoJGwOLj6AWg9taOyJN3Dnqd9NXeTCjTCwA'
>>> jwt.decode(encoded, 'secret', algorithms=['HS512'])
{'some': 'payload'}

封装jwt

# jwtauth.py
import jwt
from flask import current_app
 
def generate_jwt(payload, expiry, secret=None):
    """
    生成jwt
    :param payload: dict 载荷
    :param expiry: datetime 有效期
    :param secret: 密钥
    :return: jwt
    """
    _payload = {'exp': expiry}
    _payload.update(payload)
 
    if not secret:
        secret = current_app.config['JWT_SECRET']
 
    token = jwt.encode(_payload, secret, algorithm='HS256')
    return token.decode()
 
def verify_jwt(token, secret=None):
    """
    检验jwt
    :param token: jwt
    :param secret: 密钥
    :return: dict: payload
    """
    if not secret:
        secret = current_app.config['JWT_SECRET']
 
    try:
        payload = jwt.decode(token, secret, algorithm=['HS256'])
    except jwt.PyJWTError:
        payload = None
 
    return payload

调用jwtauth.py

>>> import jwtauth
# 到期时间为2020年4月1日17点7分0秒
>>> token = jwtauth.generate_jwt({'aaa':'111','bbb':'222'}, 1585732020, 'secret')
>>> print(token)
'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJleHAiOjE1ODU3MzIwMjAsImFhYSI6IjExMSIsImJiYiI6IjIyMiJ9.KKWEroUmY3dLbAdrnUi-kKbHd8-R916GWQhn8ozgeF8'
>>> payload = jwtauth.verify_jwt(token, 'secret')
>>> print(payload)
{'exp': 1585732020, 'aaa': '111', 'bbb': '222'}
# 时间到期
>>> payload = jwtauth.verify_jwt(token, 'secret')
>>> print(payload)
返回为空
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值