django - 在Django Rest框架中处理请求 header 以获取 header 中传递的 key 并将其保存在用户表中?

标签 django rest django-rest-framework django-rest-auth

我有一个移动应用程序的 django 后端。

我正在使用 django Rest 框架 (django-rest-auth),但我仍在编写自己的 View 和逻辑,因为 API 端点不是基于模型的。

发送给我的请求在 header 中有一个 key ,该 key 与注册的各个设备相关联。除此之外,它还包含由设备 ID 和其他详细信息组成的发布数据。

一旦我使用 request.META 获取该 header ,如何将其保存在用户模型中(它将在每次用户登录时更新),以便稍后它可以用作外键来获取所有详细信息,例如用户和关联设备。

class CustomLoginView(LoginView):
   def get_response_serializer(self):

    if getattr(settings, 'REST_USE_JWT', False):
        response_serializer = JWTSerializer
    else:
        # print(self.request.data)
        response_serializer = serializers.TokenSerializer
        # response_serializer = {'data':response_serializer}
    return response_serializer
   def get_response(self):

    # raise APIException("There was a problem!")
    serializer_class = self.get_response_serializer()
    # print(serializer_class.data)
    try:
        if getattr(settings, 'REST_USE_JWT', False):
            data = {
                'user': self.user,
                'token': self.token
            }
            serializer = serializer_class(instance=data,
                                        context={'request': self.request})
        else:
            print("hello")
            serializer = serializer_class(instance=self.token,
                                        context={'request': self.request})
            print("BYE")
            print(serializer.data)
            # print(self.request.data)
            try:
                # print(serializer.data)
                if 'email' not in self.request.POST:
                    return Response({'data':'message'})

                return Response({'data':serializer.data,'status':1,'message':'Success'}, status=status.HTTP_200_OK)
            except ValidationError as exc:
                raise ValidationError({
                        'field_val1': exc.detail,
                    })
    except:
            print("in except")
            raise APIException("There was a problem!")


   def post(self, request, *args, **kwargs):
    self.request = request
    self.serializer = self.get_serializer(data=self.request.data,
                                          context={'request': request})
    print(self.request.data)

    if self.serializer.is_valid():
        print(request.META)
        self.login()
        return self.get_response()
    else:
        return Response({"data":[],"message":"Credentials are wrong",'status':0})

我的用户模型

class User(AbstractUser):
"""User model."""

username = None
email = models.EmailField(_('email address'), unique=True)
mobile_token = models.CharField(max_length=20,blank=True)

USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []

objects = UserManager()

我的用户管理()

类 UserManager(BaseUserManager): """为没有用户名字段的用户模型定义模型管理器。"""

use_in_migrations = True

def _create_user(self, email, password, **extra_fields):
    """Create and save a User with the given email and password."""
    if not email:
        raise ValueError('The given email must be set')
    email = self.normalize_email(email)
    user = self.model(email=email, **extra_fields)
    user.set_password(password)
    user.save(using=self._db)
    return user

def create_user(self, email, password=None, **extra_fields):
    """Create and save a regular User with the given email and password."""
    extra_fields.setdefault('is_staff', False)
    extra_fields.setdefault('is_superuser', False)
    return self._create_user(email, password, **extra_fields)

def create_superuser(self, email, password, **extra_fields):
    """Create and save a SuperUser with the given email and password."""
    extra_fields.setdefault('is_staff', True)
    extra_fields.setdefault('is_superuser', True)

    if extra_fields.get('is_staff') is not True:
        raise ValueError('Superuser must have is_staff=True.')
    if extra_fields.get('is_superuser') is not True:
        raise ValueError('Superuser must have is_superuser=True.')

    return self._create_user(email, password, **extra_fields)

最佳答案

定义一个实例方法CustomLoginView中的任何位置使用它

from rest_framework.exceptions import ValidationError


class CustomLoginView(LoginView):
    <b>def save_header(self):
        headr = self.request.META.get('HTTP_MYHEADER', None)
        if headr is None:
            raise ValidationError('"MYHEADER" is missing in headers"')
        current_user = self.user
        current_user.mobile_token = headr
        current_user.save()</b>

    # your code



更新
如下更改您的 View

from rest_auth.views import LoginView
from rest_framework.exceptions import ValidationError


class CustomLoginView(LoginView):
    def save_header(self):
        headr = self.request.META.get('HTTP_MYHEADER', None)
        if headr is None:
            raise ValidationError('"MYHEADER" is missing in headers"')
        current_user = self.user
        current_user.mobile_token = headr
        current_user.save()

    def post(self, request, *args, **kwargs):
        response = super().post(request, *args, **kwargs)
        if response.status_code == 200:
            self.save_header()
        return response

您的有效负载应为

{
    "email":"<a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="fb96829e969a9297bb9e969a9297d5989496" rel="noreferrer noopener nofollow">[email protected]</a>",
    "password":"mypassword"
}



屏幕截图
1. 如何添加HEADER Headers in POSTMAN

2.如何在POSTMAN中发送数据 JSON Payload

关于django - 在Django Rest框架中处理请求 header 以获取 header 中传递的 key 并将其保存在用户表中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52175169/

相关文章:

python - django 模型表单自定义字段

python - 如何从自定义 LoginRequired 中间件中重新使用 Django Admin 登录表单

python - 如何使用 Django Rest Framework 删除对象

jQuery $.ajax 错误 : Parsing JSON Request failed with valid JSON?

django-rest-framework - DRF 注册 subview 集

python - 如何使用 django 中的中间件同时处理基于 session 和基于 token 的身份验证?

python - 在Django 1.8中,如何设置settings.py以便管理静态文件?

python - 其他列的南迁移默认值?

java - 使用 Java Rally Rest API 创建特定于用户故事的缺陷/任务

发布日期字段时djangorest 400响应