zoukankan      html  css  js  c++  java
  • django rest-framework 1.序列化 一

    上图为项目完整的目录结构

    一、入门

    需要先安装需要使用到包

    pip install django
    pip install djangorestframework

    先来创建一个新项目

    django-admin startproject restful
    cd restful
    # 创建一个应用
    python manage.py startapp rest_app  

    要想使用rest_framework 需要在django项目下的settings配置文件中的INSTALLED_APPS配置中添加如下配置:

    INSTALLED_APPS = (
        ...
        'rest_framework',
        'rest_app.apps.Test_appConfig',
    )
    # 如果您的django版本小于1.9,需要把rest_app.apps.Test_appConfig更换完rest_app
    

    二、创建一个可用的模型

    自定义一个游戏信息表

    class Game(models.Model):
        name = models.CharField(verbose_name='游戏名',max_length=64)
        company = models.CharField(verbose_name='公司',max_length=64)
        turnover = models.IntegerField(verbose_name='营业额')
        def __str__(self):
            return self.name
    # python manage.py makemigrations
    # python manage.py migrate # 生成数据库
    # python manage.py createsuperuser  # 创建管理员

    在创建数据库后,利用django admin 后台添加几条数据以备后用

    三、创建一个serializer类

    讲一下什么是serializer:

      serializer 类是用来序列化通过继承该类,可以把数据按照自定义的格式进行序列化。可以重写父类的方法对数据进行操作。

    #!/usr/bin/env python
    # -*- coding:utf-8 -*-
    __author__ = '40kuai'
    
    from rest_framework import serializers
    from test_app import models
    
    # 定义一个关于刚才新建Game表的一个序列化类,用来验证和序列化Game表数据
    class Test_app_serializer(serializers.Serializer):    # 继承serializers.Serializer类
        name = serializers.CharField(max_length=64)
        company = serializers.CharField(max_length=64)
        turnover = serializers.IntegerField()
    
        # 定义的create方法来实现新建数据,在子类中不重写改方法会raise NotImplementedError('`create()` must be implemented.')
        def create(self, validated_data):    
            return models.Game.objects.create(**validated_data)
    
        def update(self, instance, validated_data): # 同上,不重写会raise 异常
            instance.game = validated_data.get('name', instance.name)
            instance.company = validated_data.get('company', instance.company)
            instance.turnover = validated_data.get('turnover', instance.turnover)
            return instance    

    serializer类 的使用方法和django的From表单的验证相似。首先是要定义你要进行验证的字段,需要按照Game表中对数据的格式要求来定义每个字段,Serializer类也会按照自定义的字段来序列化相应的字段,

    create 和 update方法在用户进行创建,修改数据时会用到,在父类中这两个方法是要求重写的(没有强制要求)。注:父类中使用的是raise 方法来实现重写功能。

    四、路由和视图函数

    这里的路由函数是把所有的路由放到了test_app的urls.py 下,具体配置如下:

    # /restful/restful/urls.py 
    from django.conf.urls import url,include from django.contrib import admin urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^api/', include('test_app.urls')),# 指向test_app下的urls.py ]
    # /restful/test_app/urls.py
    from django.conf.urls import url from django.contrib import admin from test_app import views urlpatterns = [ url(r'^game_list/',views.game_list), # 显示所有相关信息(GET)和创建新数据(POST) url(r'^game_info/(d+)/', views.game_info),  # 显示单条数据(GET)以及对数据进行修改(POST) ]

    路由就这么点,没什么可讲的,下面才是重点,开始说下视图函数,视图函数,视图函数,视图函数,视图函数

    from django.shortcuts import render
    from django.http import HttpResponse
    from django.views.decorators.csrf import csrf_exempt  # 忽略post请求时的csrf问题
    from test_app import serializer
    from test_app import models
    from rest_framework.renderers import JSONRenderer  # restful提供的序列化类
    from rest_framework.parsers import JSONParser  # restful提供的反序列化类
    
    
    # Create your views here.
    
    
    @csrf_exempt
    def game_list(request):
        if request.method == 'GET':
            game = models.Game.objects.all()  # 获取数据库中所有数据
            game_serializer = serializer.Test_app_serializer(instance=game,
                                                             many=True)  # 通过自定义的serializer实例化数据,many参数为True表示处理多条数据
            return HttpResponse(JSONRenderer().render(game_serializer.data))  # 序列化serializer实例的数据
        elif request.method == 'POST':
            data = JSONParser().parse(request)  # 通过JsonParser类反序列化POST过来的数据
            game_serializer = serializer.Test_app_serializer(data=data)  # 通过反序列化后的数据创建serializer实例
            print(game_serializer)
            if game_serializer.is_valid():  # 通过is_valid()方法判断数据类型是否正确,这点和Django的From相似
                game_serializer.save()  # 验证通过保存数据,这里的game_serializer是自定义serializer的create函数返回的对象,进行保存
                return HttpResponse(JSONRenderer().render(game_serializer.data)) # 序列化数据返回前端
            else:  # 验证不通过,输出对应的报错信息
                print("验证不通过")
                return HttpResponse(JSONRenderer().render(game_serializer.errors)) 
    
    
    # 注释同上
    @csrf_exempt
    def game_info(request, game_id):
        game_obj = models.Game.objects.get(id=game_id)
        if request.method == 'GET':
            game_serializer = serializer.Test_app_serializer(instance=game_obj)
            data = JSONRenderer().render(game_serializer.data)
            return HttpResponse(data)
        elif request.method == 'POST':
            data = JSONParser().parse(request)
            game_serializer = serializer.Test_app_serializer(instance=game_obj, data=data)
            if game_serializer.is_valid():
                game_serializer.save()
                return HttpResponse(JSONRenderer().render(game_serializer.data))
            else:
                return HttpResponse(JSONRenderer().render(game_serializer.errors))
  • 相关阅读:
    邀请函|2021 云原生实战峰会,邀请您免费现场参会报名
    Game On Serverless:SAE 助力广州小迈提升微服务研发效能
    说出你和「云原生」的故事,获得年度云原生顶级盛会通行证
    巧用浏览器F12调试器定位系统前后端bug
    测试人员怎样定位bug原因
    mysql删除某个表前100条数据
    设计模式之工厂方法模式
    2021.11.19
    20211117
    JQuery插件集合
  • 原文地址:https://www.cnblogs.com/40kuai/p/7571985.html
Copyright © 2011-2022 走看看