• 一个DRF框架的小案例


    第一步:安装DRF

    DRF需要以下依赖:

    • Python (2.7, 3.2, 3.3, 3.4, 3.5, 3.6)

    • Django (1.10, 1.11, 2.0)

    DRF是以Django扩展应用的方式提供的,所以我们可以直接利用已有的Django环境而无需从新创建。(若没有Django环境,需要先创建环境安装Django)

    pip install djangorestframework

    第二步:添加rest_framework应用

    **settings.py****INSTALLED_APPS**中添加'rest_framework'。
    
    INSTALLED_APPS = [
        ...
        'rest_framework',
    ]

    第三步:在新建的app  book下的models.py文件中创建Book模型类,并注册到 INSTALLED_APPS 中去

    from django.db import models
    
    # Create your models here.
    class Book(models.Model):
        id=models.AutoField(primary_key=True)
        title=models.CharField(max_length=64)
        state=models.BooleanField()
        pub_date=models.DateField()
        price=models.DecimalField(max_digits=6,decimal_places=2)
        publish=models.CharField(max_length=64)

    第四步:执行数据库迁移形成数据库,并往其中添加数据

    python manage.py makemigration
    
    python manage.py migrate

    添加数据:在python的终端(Python Console) 这个终端进行
    from .mode import Book
    Book.objects.create(title="")。。。。

    得到如下数据:

    第五步:创建序列化器

    在book应用目录中新建serializers.py用于保存该应用的序列化器。

    创建一个BookInfoSerializerr用于序列化与反序列化。

    from rest_framework import serializers  # 倒入模块
     
    from book.models import Book
    class BookInfoSerializer(serializers.ModelSerializer):
        class Meta:
            model=Book
            fields="__all__"
    
    
    # - **model** 指明该序列化器处理的数据字段从模型类BookInfo参考生成
    # - **fields** 指明该序列化器包含模型类中的哪些字段,'__all__'指明包含所有字段

    第六步:编写视图函数,在book这个app下的views.py文件中创建视图BookInfoViewSet,这是一个视图集合

    # 序列化器的使用
    from rest_framework.viewsets import ModelViewSet
    from .serializers import BookInfoSerializer
    from .models import Book
    
    class BookInfoViewSet(ModelViewSet):
        queryset = Book.objects.all()
        serializer_class = BookInfoSerializer
    
    ''''
    - **queryset** 指明该视图集在查询数据时使用的查询集
    - **serializer_class** 指明该视图在进行序列化或反序列化时使用的序列化器
    '''

    第七步:定义路由,在book这个app下新建urls.py文件。并写入路由文件

    from . import views
    from rest_framework.routers import DefaultRouter
    
    
    urlpatterns=[
    
    ]
    router=DefaultRouter()  # 括号不要忘了 ,不然执行不了
    router.register(r"book",views.BookInfoViewSet)
    
    urlpatterns+=router.urls

    第八步:在总的项目路由中也要定义路由

    urlpatterns = [
        path('admin/', admin.site.urls),
        path('', include("book.urls")),   # 这个是book应用的序列化路由使用的
    
    ]

    第九步:在项目的终端启动项目

    python3 manage.py runserver

    之后访问对应url,即可看到如下

     点击 "http://127.0.0.1:8000/book/"   即可看到:所提供的api接口

      

  • 相关阅读:
    Docker核心技术之镜像(8)
    简单的自定义函数(7)
    存储过程游标的使用(6)
    存储过程循环语句(5)
    存储过程条件语句(4)
    存储过程的参数(3)
    存储过程的变量(2)
    一个简单的存储过程(1)
    Docker加速器配置(7)
    单表、多表查询
  • 原文地址:https://www.cnblogs.com/one-tom/p/11183336.html
Copyright © 2020-2023  润新知