views.py 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. from rest_framework.views import APIView
  2. from rest_framework.generics import GenericAPIView
  3. from rest_framework.response import Response
  4. from rest_framework import status
  5. from django.contrib.auth import authenticate
  6. from utils.JWTAuthentication_diy import get_token, MyJWTAuthentication
  7. from utils.permissions import RegisterViewPermission
  8. from .serializers import RegisterViewSerializer, LoginViewSerializer
  9. # Create your views here.
  10. class LoginView(APIView):
  11. def post(self, request):
  12. serializer = LoginViewSerializer(data=request.data)
  13. serializer.is_valid(raise_exception=True)
  14. request_data = serializer.validated_data
  15. user = authenticate(**request_data)
  16. if user is not None and user.is_active:
  17. token = get_token(user)
  18. return Response(token)
  19. else:
  20. return Response(data={"msg": "登录验证失败", "data": ""}, status=status.HTTP_401_UNAUTHORIZED)
  21. class RegisterView(GenericAPIView):
  22. authentication_classes = [MyJWTAuthentication]
  23. serializer_class = RegisterViewSerializer
  24. permission_classes = [RegisterViewPermission]
  25. def post(self, request):
  26. serializer = self.get_serializer(data=request.data)
  27. serializer.is_valid(raise_exception=True)
  28. serializer.save()
  29. return Response(serializer.data)