• ModelSerializer自定义验证逻辑


    ModelSerializer字段验证序列化

     # -*- coding: utf-8 -*-
     from rest_framework import serializers
     from user.models import User
    
     def address_validate(data):
      # 独立校验器
      # raise serializer.ValidationError(‘请填写实际地址’) # 有错就抛出异常
      # 没错就返回数据
      return data
    
     class UserSerializer (serializers.ModelSerializer):
      # 1.独立校验器:重新设定字段,替掉模型中的设定,重新设定地址的长度最小为5
      address = serializers.CharField(max_length=255,min_length=5,validators=[address_validate])
    
      #2.单一字段验证,验证地址
      def validate_address(self,data):
          if data == '测试':
              raise serializers.ValidationError('请填写实际地址') # 有错就抛出异常
          return data # 没错返回结果
    
      def validate_phone(self,data):
          # 不符合手机号格式
          # raise serializer.ValidationError("手机号格式不正确")
              model  =self.root.Meta.model
              num = model.object.filter(phone=data).count()
              if num > 0:
                  raise  serializers.ValidationError('手机好已存在')
              return data
    
      # 3. 所以属性验证器
      def validate(self,attrs):
          # attrs:{“user”:“zhangsan”,"phone":"17563734847",...}
          # 所有属性验证器
          # self.context中有request和view上下午
          # attrs 是需要序列化的数据
          # raise serializer.ValidationsError('xxx.错误') # 有问题报错
          return attrs # 没问题返回数据
    
      class Meta:
          model = User
          # fields = ('id') # 临时添加字段也需要写在这里
          fields = '__all__' # 所有字段
          # exclude = ['id'] # 排除id字段
          read_only_fields = ('',) # 指定字段为 read_only,
    
          # 扩展address:extra_kwargs = {} # 局部替换某些字段,或者新增设定
    
          extra_kwargs = {
              'address':{
                  'min_length' :5 ,# 给地址增加最小长度限制
                  'default' :'默认测试地址', # 增加默认值
              }
          }
    
  • 相关阅读:
    机器学习推荐系统架构图
    mysql 的读写分离 以及mycat 实现集群管理
    逻辑回归 评价推荐质量 计算AUC
    jquery编写开关实现div的显示与隐藏
    php页面post方法实现ajax,入门实例教程
    php页面get方法实现ajax,入门实例教程
    JavaScript for...in 循环 JavaScript for...in 语句循环遍历对象的属性。
    删除已有的 HTML 元素
    创建新的 HTML 元素
    js常用事件及其用法
  • 原文地址:https://www.cnblogs.com/ihszg/p/13747861.html
Copyright © 2020-2023  润新知