1.序列化类常用字段类和字段参数
1.1 常用字段类(主要字段)
CharField(字符串类型字段)
BooleanField(布尔类型字段)
IntegerField(整数字段)
DecimalField(十进制类型字段)
ListField: {name:‘lqz’,age:19,hobby:[‘篮球’,‘足球’]}
DictField:{name:‘lqz’,age:19,wife:{‘name’:‘刘亦菲’,‘age’:33}}
1.2 常用字段参数
选项参数:
参数名称 作用
给CharField字段类使用的参数
max_length 最大长度
min_lenght 最小长度
allow_blank 是否允许为空
trim_whitespace 是否截断空白字符
给IntegerField字段类使用的参数
max_value 最小值
min_value 最大值
通用参数:放在哪个字段类上都可以的
required 表明该字段在反序列化时必须输入,默认True
default 反序列化时使用的默认值
allow_null 表明该字段是否允许传入None,默认False
validators 该字段使用的验证器【不需要了解】
error_messages 包含错误编号与错误信息的字典
label 用于HTML展示API页面时,显示的字段名称
help_text 用于HTML展示API页面时,显示的字段帮助提示信息
重点
read_only 表明该字段仅用于序列化输出,默认False
write_only 表明该字段仅用于反序列化输入,默认False
2.序列化类高级用法之source,修改序列化字段名字
2.1 获取所有图书接口 APIView+Response+序列化类
2.2name字段在前端显示的时候叫book_name
-使用source,字段参数,可以指定序列化表中得哪个字段
book_name = serializers.CharField(max_length=8, min_length=3,source='name')
-source指定的可以是字段,也可以是方法,用于重命名
-source可以做跨表查询
代码演示
class BookSerializer(serializers.Serializer):
name_detail = serializers.CharField(max_length=8, min_length=3,source='name')
# 或
publish_name = serializers.CharField(max_length=8, min_length=3,source='publish.name')
# 或
xx = serializers.CharField(max_length=8, min_length=3,source='xx') #source的xx表示表模型中得方法
3.序列化类高级用法之定制序列化字段的两种方式
注册超级用户,添加表格信息
1.创建一个超级管理员,在控制台输入如下命令:
$ python manage.py createsuperuser
2.输入打算使用的登录名:
$ username:linbeixing
3.输入email(这里输不输都不影响,直接回车也可以):
$Email address:
4.输入密码,需要输入两次,输入过程中密码不显示,密码要记住:
$Password:
$Password (again):
5.当两次密码都相同的时候,就会提示superuser创建成功。:
$Superuser created successfully
6.修改密码:
$ python manage.py changepassword username
7.运行服务:
$ python manage.py runserver 127.0.0.1:8000
在浏览器打开:http://127.0.0.1:8000/admin/
也可以通过超级管理员账号登录后台修改密码: http://127.0.0.1:8000/admin/auth/user/
第一种:在【序列化类】中写SerializerMethodField
publish = serializers.SerializerMethodField()
def get_publish(self, obj):
# obj