我正在使用 django rest 框架,并且创建了一个视图来更新用户。
这是我的看法:
def put(self, request, *args, **kwargs):
authorization =UserSuitsPermissions().superuser(request.user)
userpk = kwargs.get('pk', 0)
user = get_object_or_404(STUser, pk=userpk)
if not authorization:
if request.user['id'] == user.id:
authorization = True
if authorization:
serializeddata = UserSerializer(data=request.data)
if serializeddata.is_valid(raise_exception=True):
data = serializeddata.validated_data
user.__dict__.update(**data)
user.save()
serialzed = UserSerializer(user)
return Response(serialzed.data)
return Response(status=status.HTTP_401_UNAUTHORIZED)
现在在这个链接的问题中,他们使用通用视图并使用序列化程序来更新用户实例:
接受的答案是:
def update(self, request, *args, **kwargs):
serializer = self.serializer_class(request.user, data=request.data, partial=True)
serializer.is_valid(raise_exception=True)
serializer.save()
return Response(serializer.data, status=status.HTTP_200_OK)
我没有使用通用视图,实际上我超过了它们。我不重视它。所以问题是,我们如何通过 api 视图更新用户对象?
我最大的问题是接受的答案中的这一行是否与我的代码相关?
serializer = self.serializer_class(request.user, data=request.data, partial=True)