亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

python - Django ModelSerializer 如何POST提交非Models中定義、關聯表中的字段?

瀏覽:72日期:2022-06-28 10:02:35

問題描述

我在用djangorestframwork框架為app客戶端提供接口,現在遇到個問題如下,IWannaImages表外鍵IWanna表,現在我通過接口POST提交IWanna數據的時候無法獲取客戶端POST過來的到關聯表IwannaImages的信息

這是我打印的客戶端提交的數據validated_data的內容:

{u’platform’: u’ios’, u’reason’: u’u5b81u65e5u8363u6e7fu7b54u7b54u53d1u751fu7684u53d1u7ed9u6211u7684’, u’error_type’: u’u8f6fu4ef6u9519u8bef’, u’user_id’: 56, u’wanna_type’: u’u7ea0u9519u8bef’}

從打印結果來看后臺就沒接收到客戶端傳遞的images的數據,感覺是serializer這塊不對,接口這塊該如何處理呢?

models.py

class IWanna(models.Model): wanna_type = models.CharField(max_length=32, verbose_name=_('I wanna type')) scene_name = models.CharField(max_length=128, null=True, blank=True, verbose_name=_('scene name')) city_name = models.CharField(max_length=128, null=True, blank=True, verbose_name=_('city name')) reason = models.TextField(null=True, blank=True, verbose_name=_('wanna reason')) user_id = models.IntegerField(verbose_name=_('user id')) platform = models.CharField(max_length=32, verbose_name=_('platform')) error_type = models.CharField(max_length=128, null=True, blank=True, verbose_name=_('error type')) image = models.ImageField(upload_to=wanna_image_upload_to, null=True, blank=True, verbose_name=_('image')) improve_type = models.CharField(max_length=32, null=True, blank=True, verbose_name=_('improve type')) class Meta:app_label = ’people’verbose_name = _('I Wanna')verbose_name_plural = _('I Wanna') def __unicode__(self):return '{}-{}'.format(self.id, self.wanna_type)class IWannaImages(models.Model): iwanna = models.ForeignKey('IWanna', related_name='images', verbose_name=_('i wanna type')) image = models.ImageField(upload_to=wanna_image_upload_to, verbose_name=_('image'))

serializers.py

class IWannaSerializer(serializers.ModelSerializer): images = serializers.SerializerMethodField() class Meta:model = IWannafields = ( 'id', 'wanna_type', 'scene_name', 'city_name', 'reason', 'user_id', 'platform', 'error_type', 'images', 'improve_type', 'image')depth = 1 def validate(self, attrs):if attrs['platform'] not in ['ios', 'android']: raise ValidationError({'platform': 'platform not allowed'})return attrs def get_images(self, instance):data = IWannaImageSerializer(instance.images, many=True).datareturn data def create(self, validated_data):instance = super(IWannaSerializer, self).create(validated_data)try: if validated_data['images']: # traverse images from appfor i in validated_data['images']: IWannaImages.objects.create(iwanna=instance, image=i)except Exception, e: import logging logging.warn(e.message)return instance

問題解答

回答1:

class IWannaSerializer(serializers.ModelSerializer): images = serializers.SerializerMethodField() class Meta:model = IWannafields = ( 'id', 'wanna_type', 'scene_name', 'city_name', 'reason', 'user_id', 'platform', 'error_type', 'images', 'improve_type', 'image')depth = 1

class Meta多了depth=1,所以下級的列表被過濾了,你去掉試試!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产成人精品免费视频大全办公室 | 夜夜女人国产香蕉久久精品 | 日本二区免费一片黄2019 | 欧美日韩在线观看一区 | 91久久综合九色综合欧美亚洲 | 国产原创在线观看 | 开心网五月色婷婷综合图片 | 久久99精品一久久久久久 | 日本亚欧乱色视频在线系列 | 欧美日本亚洲国产一区二区 | 99精品国产自产在线观看 | 91精品视频网站 | 青青操久久 | 一级特色黄大片 | 日本高清中文字幕一区二区三区 | 欧美日韩亚洲国产精品一区二区 | 久久精品网站免费观看 | 国产精品综合在线 | 午夜精品在线 | 调教小雪 | 麻豆精品视频入口 | 久久精品视频一区二区三区 | 日本高清免费中文字幕不卡 | 欧美在线黄 | 亚洲综合图色40p | 欧美激情综合亚洲一二区 | 欧美 magnet | 久香草视频在线观看免费 | 五月天六月婷婷开心激情 | 国产精品亚洲片夜色在线 | 999久久久国产 | 在线欧美国产 | 亚洲免费美女视频 | 免费精品久久久视频 | 亚洲天天网综合自拍图片专区 | 精品综合久久久久久99 | 三级黄色片在线免费观看 | 国产亚洲精品色一区 | 特级欧美 | 日韩在线视频www色 日韩在线视频一区 | 国产亚洲女在线精品 |