Django rest auth:从其他视图集调用RegisterView;敏感的后置参数没有';我没有收到HttpRequest

Django rest auth:从其他视图集调用RegisterView;敏感的后置参数没有';我没有收到HttpRequest,django,django-rest-framework,django-rest-auth,Django,Django Rest Framework,Django Rest Auth,在由django rest框架支持的应用程序中,我使用django rest auth和allauth来处理用户注册等操作,一切正常 我有一个API端点来处理用户的推荐。这个想法是,如果在我的网站上没有帐户的人正在添加推荐信,我想自动为他/她创建一个帐户(如果输入了电子邮件),并且应该发送欢迎电子邮件,创建个人资料,等等 因此,从处理添加推荐的视图集中,我像这样调用RegisterView;这是一个帖子: from rest_auth.registration.views import Regi

在由django rest框架支持的应用程序中,我使用django rest auth和allauth来处理用户注册等操作,一切正常

我有一个API端点来处理用户的推荐。这个想法是,如果在我的网站上没有帐户的人正在添加推荐信,我想自动为他/她创建一个帐户(如果输入了电子邮件),并且应该发送欢迎电子邮件,创建个人资料,等等

因此,从处理添加推荐的视图集中,我像这样调用RegisterView;这是一个帖子:

from rest_auth.registration.views import RegisterView

class AddTestimonialView(viewsets.ModelViewSet):
    serializer_class = TestimonialSerializer
    queryset = Testimonial.objects.all()
    permission_classes = [permissions.AllowAny, ]

def create(self, request, *args, **kwargs):
    ................
    RegisterView.as_view()(self.request)
但我得到了一个错误:

AssertionError at /api/auth/testimonial/add/
sensitive_post_parameters didn't receive an HttpRequest. If you are decorating a classmethod, be sure to use @method_decorator.
似乎我应该创建一个自定义类并重写RegisterView的一些方法,很可能是dispatch。但我不知道我该怎么做。事实上,请求根本没有敏感数据,只有电子邮件、姓名、推荐文本等,没有密码或令牌

这是来自RegisterView@rest\u auth.registration.views的原始代码:

sensitive_post_parameters_m = method_decorator(
    sensitive_post_parameters('password1', 'password2')
)

class RegisterView(CreateAPIView):
    serializer_class = RegisterSerializer
    permission_classes = register_permission_classes()
    token_model = TokenModel

    @sensitive_post_parameters_m
    def dispatch(self, *args, **kwargs):
        return super(RegisterView, self).dispatch(*args, **kwargs)

    def get_response_data(self, user):
        if allauth_settings.EMAIL_VERIFICATION == \
                allauth_settings.EmailVerificationMethod.MANDATORY:
            return {"detail": _("Verification e-mail sent.")}

        if getattr(settings, 'REST_USE_JWT', False):
            data = {
                'user': user,
                'token': self.token
            }
            return JWTSerializer(data).data
        else:
            return TokenSerializer(user.auth_token).data

    def create(self, request, *args, **kwargs):
        serializer = self.get_serializer(data=request.data)
        serializer.is_valid(raise_exception=True)
        user = self.perform_create(serializer)
        headers = self.get_success_headers(serializer.data)

        return Response(self.get_response_data(user),
                        status=status.HTTP_201_CREATED,
                        headers=headers)

    def perform_create(self, serializer):
        user = serializer.save(self.request)
        if getattr(settings, 'REST_USE_JWT', False):
            self.token = jwt_encode(user)
        else:
            create_token(self.token_model, user, serializer)

        complete_signup(self.request._request, user,
                        allauth_settings.EMAIL_VERIFICATION,
                        None)
        return user
有什么想法吗?谢谢

您能替换一下吗:

RegisterView.as_view()(self.request)


什么是类型是
self.request
?@PawełKordowski我添加了更多的代码,谢谢你把
print(type(self.request))
放在
RegisterView.as_view()(self.request)
上面,以便检查类型?@PawełKordowski它是
尝试
self.request.\u request
serializer = RegisterSerializer(data=self.request.data)
serializer.is_valid(raise_exception=True)
user = self.perform_create(serializer)