views.py 1.2 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
  9. # Create your views here.
  10. class LoginView(APIView):
  11. def post(self, request):
  12. username = request.data.get('username')
  13. password = request.data.get('password')
  14. user = authenticate(username=username, password=password)
  15. if user is not None and user.is_active:
  16. token = get_token(user)
  17. return Response(token)
  18. else:
  19. return Response(data={"msg": "登录验证失败", "data": ""}, status=status.HTTP_401_UNAUTHORIZED)
  20. class RegisterView(GenericAPIView):
  21. authentication_classes = [MyJWTAuthentication]
  22. serializer_class = RegisterViewSerializer
  23. permission_classes = [RegisterViewPermission]
  24. def post(self, request):
  25. serializer = self.get_serializer(data=request.data)
  26. serializer.is_valid()
  27. serializer.save()
  28. return Response(serializer.data)