Django使用pyJwt进行token校验

本文详细描述了在Django应用中如何进行用户登录,生成和验证JWTtoken,以及如何定义和使用自定义认证后端和装饰器来控制访问权限。
摘要由CSDN通过智能技术生成

1.登录成功后返回token,这里使用authenticate进行校验是否存在该用户

def login(request):
    try:
        data = json.loads(request.body)
        username = data.get('username')
        password = data.get('password')
        if not all([username, password]):
            return to_response(status=400, msg='参数不完整!')
        user = authenticate(username=username, password=password)
        if user:
            expiration_date = datetime.utcnow() + timedelta(seconds=settings.TOKEN_EXPIRED_TIME)
            payload = {'id': user.id, 'username': user.username, 'exp': expiration_date}
            token = encode(payload, settings.SECRET_KEY, algorithm='HS256')
            data = {
                'user': {'id': user.id, 'username': user.username},
                'token': token,
            }
            return to_response(status=200, data=data, msg='登录成功!')
        else:
            return to_response(status=400, msg='用户名或密码错误!')
    except Exception as e:
        return to_response(status=500, msg=str(e))

2.定义自定义认证后端,并在其中校验token

from django.contrib.auth.backends import BaseBackend
from users.models import UserProfile
from django.conf import settings
from jwt import decode


class MyModelBackend(BaseBackend):
    def authenticate(self, request, token=None):
        if token:
            token_info = decode(token, settings.SECRET_KEY, algorithms=['HS256'])
            user_id = token_info.get('id')
            user = UserProfile.objects.get(id=user_id)
            if user:
                return user
            else:
                return None
        else:
            return None

    def get_user(self, user_id):
        try:
            return UserProfile.objects.get(pk=user_id)
        except UserProfile.DoesNotExist:
            return None


##################在settings中配置######################################
AUTHENTICATION_BACKENDS = [
    'django.contrib.auth.backends.ModelBackend',  # 默认的 ModelBackend 也可以保留
    'django325.utils.MyModelBackend.MyModelBackend',  # 自定义的 ModelBackend'
]

3.分装装饰器

from django.contrib.auth import authenticate
from jwt import InvalidTokenError, ExpiredSignatureError

from django325.utils.response import to_response
from functools import wraps


def token_required(func):
    @wraps(func)
    def wrapper(request, *args, **kwargs):
        token = request.headers.get('Authorization')
        if token:
            try:
                user = authenticate(request=request, token=token)
            except ExpiredSignatureError:
                return to_response(status=401, msg='token已过期!')
            except InvalidTokenError:
                return to_response(status=401, msg='token验证失败')
            except Exception as e:
                return to_response(status=401, msg=str(e))
            if user:
                request.user = user
                return func(request, *args, **kwargs)
        # 用户未认证,返回错误响应
        return to_response(status=401, msg='用户未认证')

    return wrapper

4.使用

@token_required
def test(request):
    return to_response(status=200, msg='测试成功!')

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值