实战:用户模块,登录注册接口

实战:用户模块,登录注册接口

视图

from django.shortcuts import render
from rest_framework.viewsets import ViewSet
from rest_framework.decorators import action
from django.contrib.auth.hashers import make_password, check_password
from rest_framework.response import Response
from rest_framework_jwt.settings import api_settings

from .models import *
from .serializer import UserSerializer




# 注册视图
class UserRegisterView(ViewSet):
    @action(methods=["POST"], detail=False)
    def register(self, request):
        usernmae = request.data.get('username')
        password = request.data.get('password')
        re_password = request.data.get('re_password')
        is_superuser = request.data.get('is_superuser')
        if User.objects.filter(username=usernmae):
            return Response({'msg': f'用户{usernmae}已注册!', 'code': 400})
        else:
            if password == re_password:
                user_date = {'username': usernmae, 'password': make_password(password), 'is_superuser': is_superuser}
                user_serializer = UserSerializer(data=user_date)
                if user_serializer.is_valid():
                    user_serializer.save()
                    return Response({'code': 201, 'msg': f'用户{usernmae}注册成功'})
                else:
                    print(user_serializer.errors)
                    return Response({'code': 401, 'msg': '注册失败', 'errors': user_serializer.errors})
            else:
                return Response({'msg': '两次密码不一致', 'code': 402})


class UserLoginView(ViewSet):
    @action(methods=["POST"], detail=False)
    def login(self, request):
        username = request.data.get('username')
        password = request.data.get('password')
        user = User.objects.filter(username=username).first()
        # 载荷
        jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
        jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER
        response_dict = {'code': 100, 'msg': None}
        if user and check_password(password, user.password):
            # 登录成功签发token

            # 载荷
            payload = jwt_payload_handler(user)
            # token
            token = jwt_encode_handler(payload)
            response_dict['token'] = token
            response_dict['msg'] = f'{user.username} Login successfuly!'

        else: # 登录失败
            response_dict['code'] = 101
            response_dict['msg'] = 'Login Failed, The user name or password is incorrect! '
        return Response(response_dict)

序列化


from rest_framework import serializers

from .models import *

# 逻辑写视图
class UserSerializer(serializers.ModelSerializer):
    class Meta:
        model = User
        fields = '__all__'

模型

from django.contrib.auth.models import AbstractUser
from django.db import models

# 用户表
class User(AbstractUser):
    telephone = models.CharField(max_length=11, null=True, unique=True)

    class Meta:
        verbose_name_plural = '用户表'

    def __str__(self):
        return self.username

路由


from django.contrib import admin
from django.urls import path,include
from app01 import views
from rest_framework.routers import SimpleRouter
router = SimpleRouter()

router.register('user',views.UserLoginView,'user')
router.register('user',views.UserRegisterView,'user')

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', include(router.urls)),
]

posted @ 2022-04-16 18:59  HammerZe  阅读(127)  评论(0编辑  收藏  举报