首页 > 解决方案 > 如何在 Django Rest Framework 的视图集中添加对自定义操作的特定访问级别?

问题描述

我在 Django Rest Framework 中有一个具有所有 crud 功能的 ModelViewSet,并将权限设置为 IsAuthenticated,但我做了一个自定义操作并希望它公开,但我不知道如何做到这一点,因为文档只显示了如何做使用@api_view(),这是我的 ModelViewSet

class UserViewSet(viewsets.ModelViewSet):
    """User viewset"""

    queryset = User.objects.all()
    serializer_class = UserModelSerializer
    authentication_classes = [TokenAuthentication]
    permission_classes = [IsAuthenticated]

    @action(detail=False, methods=['post'])
    def signup(self, request):
        """Sign Up users without profile. """
        serializer = UserSignUpSerializer(data=request.data)
        if serializer.is_valid(raise_exception=True):
            user = serializer.save()
            data = {
                'user' : user,
            }
            return Response(data, status=status.HTTP_201_CREATED)

    @action(detail=False, methods=['post'])     
    def login(self, request, *args, **kwargs):
        """ Handle logins request. """
        serializer = UserLoginSerializer(data=request.data)
        serializer.is_valid(raise_exception=True)
        user, token = serializer.save()
        data= {
            'user': user,
            'access_token' : token
        }
        return Response(data, status=status.HTTP_201_CREATED)

我想公开登录@action,希望你们能帮助我

标签: pythondjangodjango-rest-frameworkauthorization

解决方案


您可以将参数添加到操作 deacrotor 以更改权限类。

    @action(detail=False, methods=['post'], permission_classes=[AllowAny])     
    def login(self, request, *args, **kwargs):
        """ Handle logins request. """
        serializer = UserLoginSerializer(data=request.data)
        serializer.is_valid(raise_exception=True)
        user, token = serializer.save()
        data= {
            'user': user,
            'access_token' : token
        }
        return Response(data, status=status.HTTP_201_CREATED)

文档中的详细信息


推荐阅读