如何序列化django-mysql的JSON字段

时间:2018-10-30 10:49:01

标签: python django django-rest-framework

我正在将django与django-mysql库一起使用,以便能够利用其JSON字段。

但是,我在为模型编写序列化程序时遇到问题。这是模型:

models.py

from django_mysql.models import JSONField, Model

class PhoneTest(Model):
    data = JSONField()

views.py

class PhoneTestView(viewsets.ViewSet):
    serializer_class = PhoneTestSerializer

    def create(self, request):
        serializer = self.serializer_class(data=request.data)
        if serializer.is_valid():
            print('data is valid: {}'.format(serializer.data))
            print('saving to a db...')
            serializer.save()
        else:
            print('data is not valid: {}'.format(serializer.data))

        return Response(serializer.data, status=status.HTTP_200_OK)

serializers.py

class PhoneTestSerializer(serializers.ModelSerializer):
    data = serializers.JSONField(binary=True)

    class Meta:
        model = PhoneTest
        fields = ['data']

返回的是一个空对象{}。当然,这是串行器的问题。我想我确实可以完全避免使用它,而编写类似的内容:

PhoneTest.objects.create(data=request.data)

但是我不确定是不是邦通。

编辑

这是我要发布的json的样子:

{'mAutomaticTestCompleted': True, 'mAutomaticTestList': [{'mCountWifiNetworks': 17, 'mName': 'Wifi module', 'mTestStatus': True}, {'mName': 'Bluetooth module', 'mTestStatus': False}, {'mName': 'Battery module', 'mTestStatus': True, 'mValue': -748}, {'mAvailableRamSize': 1036046336, 'mName': 'Memory module', 'mTestStatus': False, 'mTotalRamSize': 1949261824}, {'mAvailableStorageSize': 10391855104, 'mName': 'Internal storage module', 'mTestStatus': True, 'mTotalStorageSize': 11810320384}, {'mAdvancedStatus': True, 'mAvailableEasy': 10391855104, 'mEasyStatusTest': True, 'mName': 'SD card module', 'mTestStatus': True, 'mTotalEasy': 11810320384}, {'mGsmStatus': False, 'mName': 'GSM module', 'mSimStatus': False, 'mTestStatus': False}, {'mName': 'Accelerator module', 'mTestStatus': True, 'mX': 2.49, 'mY': 4.98, 'mZ': 10.34}, {'mName': 'Light Sensor module', 'mTestStatus': True, 'mValue': 145}], 'mDeviceManufacturer': 'Vertex', 'mDeviceModelName': 'Impress_Phonic', 'mGlobalDeviceStatus': False, 'mImei': '097264011583257', 'mMac': '02:00:00:00:00:00', 'mManualTestList': [{'mName': 'Display module', 'mTestStatus': False}, {'mName': 'Back Light module', 'mTestStatus': True}, {'mName': 'Flashlight module', 'mTestStatus': True}, {'mName': 'Headset or jack module', 'mTestStatus': True}, {'mName': 'Receiver module', 'mTestStatus': True}, {'mName': 'Speaker module', 'mTestStatus': True}, {'mName': 'Vibration module', 'mTestStatus': True}], 'mOfficerCode': 'xian', 'mSemiautomaticTestList': [{'mName': 'QR code module', 'mTestStatus': True}, {'mName': 'Buttons module', 'mTestStatus': False}, {'mName': 'Microphone module', 'mTestStatus': True}, {'mCounter': 0, 'mName': 'Multitouch module', 'mTestStatus': True}, {'mName': 'GPS module', 'mTestStatus': True}, {'mName': 'PSensor module', 'mTestStatus': True}, {'mName': 'Touchscreen module', 'mTestStatus': True}], 'mDate': '10/5/2018, 11:05:04 AM'}

1 个答案:

答案 0 :(得分:1)

此行

serializer = self.serializer_class(data=request.data)

期望json格式为

{'data': {'mAutomaticTestCompleted': True, 'mAutomaticTestList': [{'mCountWifiNetworks': 17, 'mName': 'Wifi module', 'mTestStatus': True}, {'mName': 'Bluetooth module', 'mTestStatus': False}, {'mName': 'Battery module', 'mTestStatus': True, 'mValue': -748}, {'mAvailableRamSize': 1036046336, 'mName': 'Memory module', 'mTestStatus': False, 'mTotalRamSize': 1949261824}, {'mAvailableStorageSize': 10391855104, 'mName': 'Internal storage module', 'mTestStatus': True, 'mTotalStorageSize': 11810320384}, {'mAdvancedStatus': True, 'mAvailableEasy': 10391855104, 'mEasyStatusTest': True, 'mName': 'SD card module', 'mTestStatus': True, 'mTotalEasy': 11810320384}, {'mGsmStatus': False, 'mName': 'GSM module', 'mSimStatus': False, 'mTestStatus': False}, {'mName': 'Accelerator module', 'mTestStatus': True, 'mX': 2.49, 'mY': 4.98, 'mZ': 10.34}, {'mName': 'Light Sensor module', 'mTestStatus': True, 'mValue': 145}], 'mDeviceManufacturer': 'Vertex', 'mDeviceModelName': 'Impress_Phonic', 'mGlobalDeviceStatus': False, 'mImei': '097264011583257', 'mMac': '02:00:00:00:00:00', 'mManualTestList': [{'mName': 'Display module', 'mTestStatus': False}, {'mName': 'Back Light module', 'mTestStatus': True}, {'mName': 'Flashlight module', 'mTestStatus': True}, {'mName': 'Headset or jack module', 'mTestStatus': True}, {'mName': 'Receiver module', 'mTestStatus': True}, {'mName': 'Speaker module', 'mTestStatus': True}, {'mName': 'Vibration module', 'mTestStatus': True}], 'mOfficerCode': 'xian', 'mSemiautomaticTestList': [{'mName': 'QR code module', 'mTestStatus': True}, {'mName': 'Buttons module', 'mTestStatus': False}, {'mName': 'Microphone module', 'mTestStatus': True}, {'mCounter': 0, 'mName': 'Multitouch module', 'mTestStatus': True}, {'mName': 'GPS module', 'mTestStatus': True}, {'mName': 'PSensor module', 'mTestStatus': True}, {'mName': 'Touchscreen module', 'mTestStatus': True}], 'mDate': '10/5/2018, 11:05:04 AM'}}

**请注意data属性-在这种情况下很重要

这就是为什么它不提取您的帖子内容。修改您的有效载荷,它应该正确拾取。