基于jwt模块实现登录功能

view代码

from rest_framework.views import APIView
from rest_framework.response import Response


class Login(APIView):
    '''
    登录模块
    '''
    def post(self,request):
        # 获取用户名
        name = request.data.get('name')
        # 获取密码
        password = request.data.get('password')
        # 判断参数完整性
        if not all([name, password]):
            return Response({'msg': '请输入完整的账号密码', 'code': 400})
        # 查询是否有该用户
        find_user_first = User.objects.filter(name=name).first()
        if not find_user_first:
            return Response({'msg': '没有找到此用户', 'code': 400})
        # 生成token对象
        jwt_obj = JwtClass()
        # 生成token
        token = jwt_obj.create_token(user_number=find_user_first.user_number)
        queryset = User.objects.filter(name=name).first()
        ser_obj = LoginSer(queryset)
        if not token:
            return Response({'msg': '生成标识失败', 'code': 400})
        return Response({'msg': '登录成功', 'code': 200, 'token': token, 'data': ser_obj.data})

jwt.py代码

# jwt万能类
import jwt
import datetime
from .settings import SECRET_KEY
# from apps.user.models import User


class JwtClass(object):
    # 加密token
    def create_token(self, user_number):
        '''
        加密token
        :param user_number:
        :return:
        '''
        if user_number:
            try:
                # 过期时间为一天
                token = jwt.encode(
                    {
                        'user_number': user_number,
                        'exp': datetime.datetime.now() + datetime.timedelta(days=1)
                    },
                    key=SECRET_KEY, algorithm='HS256'
                )
            except Exception as err:
                print(err)
                return None
            return token
        else:
            return None

    # 解密token
    def check_token(self, token):
        '''
        解密token
        :param token:
        :return:
        '''
        if token:
            try:
                data = jwt.decode(token, key=SECRET_KEY, algorithms=['HS256'])
                user_number = data['user_number']
            except Exception as err:
                print(err)
                print('解密失败')
                return None
            else:
                if User.objects.filter(user_number=user_number):
                    return user_number
                else:
                    return None
        else:
            return None

models代码

class User(models.Model):
    name = models.CharField(max_length=256, verbose_name='用户名')
    password = models.CharField(max_length=256, verbose_name='密码')

serlizer代码

class UserSer(serializers.ModelSerializer):
    class Meta:
        model = User
        fields = "__all__"

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值