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