序列化组件与解析器

rest-framework之ModelSerializer

class BookSerializers(serializers.ModelSerializer): class Meta: model = models.Book # fields = "__all__" fields=['nid','title','authors','publish'] # exclude=('nid',) #不能跟fields同时用 # depth = 1 #深度控制,写 往里拿几层,层数越多,响应越慢,官方建议0--10之间,个人建议最多3层 publish=serializers.SerializerMethodField() def get_publish(self,obj): return obj.publish.name authors=serializers.SerializerMethodField() def get_authors(self,obj): ret=obj.authors.all() ss=AuthorSerializer(ret,many=True) return ss.data 

序列化组件之请求数据校验和保存功能

class BookSerializers(serializers.ModelSerializer):
    class Meta: model=Book fields="__all__" title = serializers.CharField(error_messages={'required': '标题必填'}) def validate_title(self, value): # 局部钩子 from rest_framework.exceptions import ValidationError if value.isdigit(): raise ValidationError('不能是数字') return value def validate(self, attrs): # 全局钩子 from rest_framework.exceptions import ValidationError if attrs.get('title') == attrs.get('publish'): raise ValidationError('书名与出版社不能相同') return attrs #———————— class BookView(APIView): def post(self, request): # 添加一条数据 print(request.data) bs=BookSerializers(data=request.data) if bs.is_valid(): bs.save() # 生成记录 return Response(bs.data) else: return Response(bs.errors) 

解析器

解析器的作用
根据请求头 content-type 选择对应的解析器对请求体内容进行处理。

有application/json,x-www-form-urlencodedform-data等格式 
全局解析器

setting里

REST_FRAMEWORK = {
    'DEFAULT_PARSER_CLASSES':[
        'rest_framework.parsers.JSONParser'
        'rest_framework.parsers.FormParser' 'rest_framework.parsers.MultiPartParser' ] } 
局部解析器
class TestView(APIView):
    parser_classes = [JSONParser, ]  # 名字必须为parser_classes,[]中为解析器类型

转载于:https://www.cnblogs.com/luck-L/p/9793197.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值