serializers.Serializer
class Userinfoserializers(serializers.Serializer):
    username = serializers.CharField()
    passwd = serializers.CharField()
    group = serializers.CharField(source="group.title")
        #使用序列化的原因:
        #因为在传统的前后端不分离后台返回给前端的数据类型为Queryset对象而不是可视化对象所以我们可以通过rest_framework的serializers类将Queryset对象变成我们想要的数据格式
        #当source参数存在的时候会直接通过source的参数作为键到数据库取值,如果不存在则通过变量名为键取值
        #当source参数不存在时,键为变量名,且通过变量名为键取值
        #当source数据源明确时可以自定义变量名为响应数据的键  oooo = serializers.CharField(source=“username”)
        #source参数也可以为一个方法在内部会自动加上括号比如source="get_字段名_display"
        #也可以通过外键取值source="group.title"

class Userinfo_view(APIView):
    def get(self,request,*args,**kwargs):

        #实现的原理如下通过返回的对象调用values方法返回指定的字段值
        #info = models.UserInfo.objects.all().values("id","username","passwd")

        mdl = models.UserInfo.objects.all()

        #many 为传入的数据为多条的话为True 如果不是一个列表只有一条的话则为False
        ser = Userinfoserializers(instance=mdl,many=True)
        info = json.dumps(ser.data,ensure_ascii=False)
        return HttpResponse(info)

自定义显示

class Userinfoserializers(serializers.Serializer):
    username = serializers.CharField()
    passwd = serializers.SerializerMethodField()

    #此处的value为一个Queryser对象get_字段名
    def get_passwd(self,value):
        return value.passwd

class Userinfo_view(APIView):
    def get(self,request,*args,**kwargs):
        mdl = models.UserInfo.objects.all()
        ser = Userinfoserializers(instance=mdl,many=True)
        info = json.dumps(ser.data,ensure_ascii=False)
        return HttpResponse(info)

生成 HyperlinkedIdentityField

生成HyperlinkedIdentityField
url(r"^(?P<version>[v1|v2]+)/group/(?P<group_id>\d+)$",views.Groupinfo_view.as_view(),name="group"),

class Userinfoserializers(serializers.ModelSerializer):
    #lookup_field=此参数必须在路有中出现,view_name="group"找寻的是路由别名,也决定了他的生成格式
    group = serializers.HyperlinkedIdentityField(view_name="group",lookup_field="group_id")
    class Meta:
        model = models.UserInfo
        fields = "__all__"

class Userinfo_view(APIView):
    def get(self,request,*args,**kwargs):
        mdl = models.UserInfo.objects.all()
        #必填参数context={"request":request}
        ser = Userinfoserializers(instance=mdl,many=True,context={"request":request})
        info = json.dumps(ser.data,ensure_ascii=False,)
        return HttpResponse(info)
serializers.ModelSerializer
    #两者也可配合使用
    class Userinfoserializers(serializers.ModelSerializer):
    class Meta:

        #深度控制,此处的值为多少层表默认为0
        depth = 1 #0-10
        model = models.UserInfo

        #显示所有字段
        # fields = "__all__"

        #此处可以自定义显示的字段
        fields = ["id","username","passwd","user_type","group"]

        #此处通过字典的方式也可以取到对应的外键的值
        extra_kwarges = {"group":{"source":"group.title"},}

         #也可以自定义字段
            class MyField(serializers.CharField):
                #此处接收value为Queryset对象
                def to_representation(self,value):
                    return valu
 请求数据校验

class Roleser(serializers.ModelSerializer):    title = serializers.CharField(min_length=3,max_length=5,error_messages={"min_length":"字数不能低于3","max_length":"字数不能大于5"})

    def validate_title(self, attrs):#对指定字段进行自定义校验        print(attrs)#销售2        return attrs    def validate(self, attrs):#对多个字段进行校验        print(attrs)#OrderedDict([('title', '销售2')])        return attrs

class Roles_view(APIView):    def get(self,request,*args,**kwargs):        obj = models.Role.objects.all()        ser = Roleser(instance=obj,many=True)        return Response(ser.data)

    def post(self,request,*args,**kwargs):        ser = Roleser(data=request.data)        if ser.is_valid():            ser.save()            return Response("提交成功")        else:            return Response(ser.errors)
 

 
 
 

restframework序列化使用方法的更多相关文章

  1. rest-framework序列化

    快速实例 Quickstart 序列化 开篇介绍: ---- 一切皆是资源,操作只是请求方式 ----book表增删改查 /books/ books /books/add/ addbook /book ...

  2. JavaScript表单序列化的方法详解

    本文介绍下,在javascript中实现表单序列化的方法,通过实例加深理解,有需要的朋友参考下吧. 在JavaScript中,可以利用表单字段的type属性,连同name和value属性一起实现对表单 ...

  3. Map,List,POJO深拷贝(序列化实现)方法与注意事项

    转载请注明出处,谢谢! 方法1: /*jdk >= 1.5*/ @SuppressWarnings("unchecked") public static <T> ...

  4. 两种序列化的方法 Serializable Parcelable

    原文:https://blog.csdn.net/hacker_crazy/article/details/80840868 一.Serializable 1.Serializable 是java的序 ...

  5. rest-framework 序列化格式Restful API设计规范

    理解RESTful架构 Restful API设计指南 理解RESTful架构 越来越多的人开始意识到,网站即软件,而且是一种新型的软件. 这种"互联网软件"采用客户端/服务器模式 ...

  6. 从django的序列化到rest-framework 序列化

    1.利用Django的view实现返回json数据 from django.views.generic import View from goods.models import Goods class ...

  7. day 94 RestFramework序列化组件与视图view

    一 .复习 1. CBV流程 class BookView(View): def get(): pass def post(): pass #url(r'^books/', views.BookVie ...

  8. django restframework 序列化

    Serialization 序列化 创建表 from django.db import models from pygments.lexers import get_all_lexers from p ...

  9. Django restframework 序列化之 ModelSerializer 小记

    首先介绍一下相关概念 序列化器(Serializer) 1. 自定义型:  继承rest_framework.serializers.Serializer 2. 模型类型:  继承rest_frame ...

随机推荐

  1. 通过注解实现Spring 声明式事务管理

    小Alan接着上一篇Spring事务管理入门与进阶做一些补充,如果对Spring事务管理还不了解的可以看看上一篇文章. 实例 在我们开始之前,至少有两个数据库表是至关重要的,在事务的帮助下,我们可以实 ...

  2. Sublime Text 3.1 3170正式版+Patch注册机

        Sublime Text 是一款轻量级的代码编辑器,也是HTML和散文先进的文本编辑器.Sublime Text 具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等. ...

  3. Java笔记-添加自定义公共类库

    大型项目,为了方便团队开发,需要建立公共类库,提高类库的重用性和维护性步骤如下: --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/387 ...

  4. php中的extract函数

    extract函数用来将一个数字分解成多个变量直接使用,下面是W3C的解释:PHP extract() 函数从数组中把变量导入到当前的符号表中.对于数组中的每个元素,键名用于变量名,键值用于变量值.第 ...

  5. 原生JS写了一个小demo,根据输入的数字生成不同背景颜色的小方块儿~

    昨天练习写了这个小demo,个人觉得通过设置定位元素left和top的值,来实现换行的功能,这种方法很巧妙~ 另外,如下代码中的随机颜色的获取,还请各位前辈多多指教:需要改进的地方:或者有没有更好的方 ...

  6. jq实现多级菜单

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  7. Django settings.py 的media路径设置

    转载自:http://www.xuebuyuan.com/676599.html 在一个 models 中使用 FileField 或 ImageField 需要以下步骤: 1. 在你的 settin ...

  8. mysql 聚集和非聚集索引 解析

    一.聚集索引(聚簇索引) 1. 什么是聚集索引? 比如要查找'hello',则直接找内容为hello的行,我们把这种正文内容本身就是一种按照一定规则排列的目录称为“聚集索引”.   聚集索引的叶子节点 ...

  9. [emerg]: getpwnam(“nginx”) failed

    [root@localhost nginx-1.11.2]# /usr/local/nginx/sbin/nginx nginx: [emerg] getpwnam("nginx" ...

  10. BZOJ1731:[USACO]Layout 排队布局(差分约束)

    Description Like everyone else, cows like to stand close to their friends when queuing for feed. FJ ...