加入收藏 | 设为首页 | 会员中心 | 我要投稿 大庆站长网 (https://www.0459zz.com/)- 科技、智能边缘云、事件网格、云计算、站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – Django REST Framework中的camelCase POST数据

发布时间:2020-09-19 08:18:48 所属栏目:Python 来源:互联网
导读:我看到有一个名为djangorestframework-camel-case的项目,允许在Django REST序列化程序中使用带有下划线字段的JavaScript-ish camelCase.所以,基本上,我可以发送:{ camelCase: foo } 并使用以下Serializer接收它:class MySerializer(seria

我看到有一个名为djangorestframework-camel-case的项目,允许在Django REST序列化程序中使用带有下划线字段的JavaScript-ish camelCase.所以,基本上,我可以发送:

{
    "camelCase": "foo"
}

并使用以下Serializer接收它:

class MySerializer(serializers.Serializer):
    session_id = serializers.CharField()

是否存在类似POST数据的内容?所以我可以通过POST发送camelCase = foo并将其接收到我的序列化器中的underscore_case字段?

我尝试基于FormParser实现自己的解析器:

class CamelCaseFormParser(FormParser):
    media_type = 'application/x-www-form-urlencoded'

    def __init__(self):
        print("initialized")

    def parse(self,stream,media_type=None,parser_context=None):
        print("parse")
        ...

并且,在将其添加到settings.py中的DEFAULT_PARSER_CLASSES之后,虽然实际打印了初始化,但解析不是.所以看来,在POST数据的情况下,根本不使用application / x-www-form-urlencoded解析器.

由于Serializers的使用方式如下:

Serializer(data=request.data)

我正在考虑继承Serializer并在进一步处理之前修改数据,甚至在创建Serializer之前修改它.但我要求的是一种更方便的方法,适用于所有的Serializers,而无需对它们进行子类化. 最佳答案 为什么不坚持使用解析器?

from djangorestframework_camel_case.util import underscoreize
from rest_framework import parsers
from django.conf import settings
from django.http import QueryDict


class CamelCaseFormParser(parsers.FormParser):
    def parse(self,parser_context=None):
        parser_context = parser_context or {}
        encoding = parser_context.get('encoding',settings.DEFAULT_CHARSET)
        data = QueryDict(stream.read(),encoding=encoding)
        return underscoreize(data)

简单,工作和正确放置……

(编辑:大庆站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读