Django Rest——”;序列化程序.data“;是空的dict(),即使;“序列化程序”;有详细的数据

Django Rest——”;序列化程序.data“;是空的dict(),即使;“序列化程序”;有详细的数据,django,rest,serialization,Django,Rest,Serialization,我试图根据stackoverflow上的一些建议来实现密码更改,但有些东西不起作用,这对我来说真的很奇怪。排除故障后,我得到了idea数据,“我的视图”不起作用。将序列化程序操作更改为打印我看到数据“serializer.data”是结果“{}”,即使“print(serializer)”给出了结果 序列化程序.py class ChangePasswordSerializer(serializers.Serializer): old_password = serializers.Cha

我试图根据stackoverflow上的一些建议来实现密码更改,但有些东西不起作用,这对我来说真的很奇怪。排除故障后,我得到了idea数据,“我的视图”不起作用。将序列化程序操作更改为打印我看到数据“serializer.data”是结果“{}”,即使“print(serializer)”给出了结果

序列化程序.py

class ChangePasswordSerializer(serializers.Serializer):
    old_password = serializers.CharField(max_length=128, write_only=True, required=True)
    new_password1 = serializers.CharField(
        max_length=128, write_only=True, required=True
    )
    new_password2 = serializers.CharField(
        max_length=128, write_only=True, required=True
    )

    def validate_old_password(self, value):
        user = self.context["request"].user
        if not user.check_password(value):
            raise serializers.ValidationError(
                {
                    "old_passowrd": _(
                        "Your old password was entered incorrectly. Please enter it again."
                    )
                }
            )
        return value

    def validate(self, data):
        if data["new_password1"] != data["new_password2"]:
            raise serializers.ValidationError(
                {"new_password2": _("The two password fields didn't match.")}
            )
        validate_password(data["new_password1"], self.context["request"].user)
        return super().validate(data)
views.py

class ChangePassword(UpdateAPIView):
    serializer_class = ChangePasswordSerializer
    permission_classes = [IsAuthenticated]

    def get_object(self, queryset=None):
        return self.request.user

    def update(self, request, *args, **kwargs):
        self.object = self.get_object()
        serializer = self.get_serializer(data=request.data)
        if serializer.is_valid(raise_exception=True):
            # user.set_password(serializer.data.get("new_password1"))
            # user.save()
            print(serializer.data)
            return Response("Success", status=status.HTTP_204_NO_CONTENT)
        return Response(serializer.errors, status.HTTP_400_BAD_REQUEST)


序列化表示时不包括“write\u only=True”字段。如果要调试,可以打印
request.data
或仅删除参数write\u或将其设置为False


非常感谢,我知道了。请再问一个问题,与我的用户关联的令牌是否在密码更改过程中被删除,或者我必须为其添加功能?如果您使用默认令牌身份验证,则需要手动生成新令牌。我使用的是Simple JWTGet,然后您可以使用下面的功能<代码>从rest\u框架\u simplejwt.tokens导入RefreshToken
RefreshToken.for\u用户(request.user)