一.创建项目

1.创建 项目 :

django-admin  startprojet  drf 

2. 创建 两个app   ------ app1 ,book

python manage.py  startapp  app1

python manage.py  startapp  book

3. settings 配置  ,一定不能少了 rest_framework 这个app的注册。

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'book',
  'app1',
]
# 连接数据库

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'book', # 数据库名
'HOST':'127.0.0.1',
'PORT':3306,
'USER':'root',
'PASSWORD':'' # 这里必须为字符串
}
}

4. 主应用中 __init__.py 文件中:

import pymysql

pymysql.install_as_MySQLdb()

5.  bookapp 中的  model.py 中建表

from django.db import models

# Create your models here.

class Book(models.Model):

    title = models.CharField(max_length=32,verbose_name='书名')

    pub_date = models.DateField(verbose_name='出版日期')

    bread = models.IntegerField(verbose_name='阅读量')

    bcomment = models.IntegerField(verbose_name='评论数')

    class Meta:

        db_table ='book'

    def __str__(self):

        return self.title

class Hero(models.Model):

    name = models.CharField(max_length=32,verbose_name='名字')

    age = models.IntegerField(verbose_name='年龄')

    class Meta:

        db_table='人物'

    def __str__(self):

        return self.name

6. 数据库迁移。

python manage.py  makemigrations

python manage.py  migrate

7. 在表中录入数据。

接口实现

1.在app1 先创建serializers.py 文件

from rest_framework import serializers

from book.models import Book,Hero

class BookModelSerializer(serializers.ModelSerializer):

    class Meta:
model = Book fields='__all__' # 可以给模型序列化器里面指定的字段设置限制选项
extra_kwargs = {
'bread':{'min_value':0,'required':True}
} class HeroModelSerializer(serializers.ModelSerializer): class Meta:
model = Hero fields = '__all__'

2. app1  views.py  创建视图

from django.shortcuts import render

# Create your views here.
from rest_framework.decorators import action
from rest_framework.response import Response
from rest_framework.viewsets import ModelViewSet
from app1.serializers import BookModelSerializer, HeroModelSerializer
from book.models import Book, Hero class BookModelViewSet(ModelViewSet):
queryset = Book.objects.all()
serializer_class = BookModelSerializer @action(methods=['get'],detail=False)#detail=False 是否为详情页数据
def get_top_5(self,request): # 其接口 http://127.0.0.1:8000/app1/book/get_top_5/
# 获取阅读量最多的5条数据
books = Book.objects.order_by('-bread')[:5] # 取阅读量为前5的书籍 serializer = BookModelSerializer(instance=books,many=True) return Response(serializer.data) # action是drf提供的路由和视图方法绑定关系的装饰器
# from rest_framework.decorators import action
# 参数1: methods 列表,设置视图方法允许哪些http请求访问进来
# 参数2: detail 当前是否方法是否属于详情页视图,
# False,系统不会自动增加pk在生成的路由地址中
# True 则系统会自动增加pk在生成的路由地址
@action(methods=['get','post'],detail=True)
def get_one_title(self,request,pk): book = Book.objects.get(pk=pk) return Response(book.btitle) class HeroModelViewSet(ModelViewSet): queryset = Hero.objects.all() serializer_class = HeroModelSerializer

3. 配置路由

  1.app1 应用下创建一个路由文件  urls.py

from rest_framework import routers

from app1.views import BookModelViewSet, HeroModelViewSet

urlpatterns=[]

router = routers.DefaultRouter() # 开发环境用,有主界面
# router = routers.SimpleRouter() # 生产环境用

router.register('book',BookModelViewSet)
router.register('hero',HeroModelViewSet) urlpatterns += router.urls

  2.主应用下 urls.py 文件中

from django.contrib import admin
from django.urls import path,include urlpatterns = [
path('admin/', admin.site.urls),
path('app1/',include('app1.urls'))
]

经过上面的创建完成了 book表和hero 表的增删改查功能的API接口的实现。

DefaultRouter()的区别  SimpleRouter()

DefaultRouter() 可以多返回一个主页面,而 simleRouter 没有以下的页面。
												

ModelViewSet 视图集 实现接口的更多相关文章

  1. DRF中的视图集的使用

    1.说明:DRF框架中的视图集: 在drf开发接口中,使用GenericAPIView和视图扩展类结合起来完成接口功能是一件很常见的事情,所以,drf的作者帮我们提前把  GenericAPIView ...

  2. 068.Python框架Django之DRF视图集使用

    一 视图集与路由的使用 使用视图集ViewSet,可以将一系列逻辑相关的动作放到一个类中: list() 提供一组数据 retrieve() 提供单个数据 create() 创建数据 update() ...

  3. Django(58)viewsets视图集详解

    前言 ViewSet 只是一种基于类的视图,它不提供任何方法处理程序(如 .get()或.post()),而是提供诸如.list()和 .create() 之类的操作. ViewSet 的方法处理程序 ...

  4. 对drf视图集的理解

    视图集ViewSet 使用视图集ViewSet,可以将一系列逻辑相关的动作放到一个类中: list() 提供一组数据 retrieve() 提供单个数据 create() 创建数据 update() ...

  5. DRF中五大扩展类及视图集的介绍

    五个扩展类 (1)ListModelMixin 列表视图扩展类,提供list(request, *args, **kwargs)方法快速实现列表视图,返回200状态码. 该Mixin的list方法会对 ...

  6. 使用DRF视图集时自定义action方法

    在我们用DRF视图集完成了查找全部部门,创建一个新的部门,查找一个部门,修改一个部门,删除一个部门的功能后,views.py的代码是这样子的: class DepartmentViewSet(Mode ...

  7. 06_Tutorial 6: ViewSets & Routers 视图集与路由器

    1.Tutorial 6: ViewSets & Routers 视图集与路由器 0.文档 https://q1mi.github.io/Django-REST-framework-docum ...

  8. 小波说雨燕 第三季 构建 swift UI 之 UI组件集-视图集(六)Picker View视图 学习笔记

    想对PickerView进行操作,只能在代码中操作. 下面 ,再添加三个label组件,然后将所有组件配置到代码中(看代码),然后要实现对PickerView的操作,就要实现它的DataSource协 ...

  9. 多结果集IMultipleResult接口

    在某些任务中,需要执行多条sql语句,这样一次会返回多个结果集,在应用程序就需要处理多个结果集,在OLEDB中支持多结果集的接口是IMultipleResult. 查询数据源是否支持多结果集 并不是所 ...

随机推荐

  1. UVALive 7503 Change(乱搞)题解

    题意:你现在有面额为A的纸币,现在需要面额为B的钱(可以是一张也可以是好多张拼成一张),有一台自动售货机,里面有任意价格的商品,售货机兑换出的零钱是随机的(比如找你0.03可能给你0.01+0.01+ ...

  2. Why database migrations?

    https://flywaydb.org/getstarted/why First, let's start from the beginning and assume we have a proje ...

  3. JZ2440存储管理器--SDRAM

     为了cpu访问外部设备,ARM提供一个存储管理器部件,提供访问外部设备的所需的信号(对SDRAM.网卡.nor等设备进行初始化,以便存储器管理器配合CPU进行与外设数据通讯).   CPU通常读写一 ...

  4. Ambari配置Hive,Hive的使用

    mysql安装,hive环境的搭建 ambari部署hadoop 博客大牛:董的博客 ambari使用 ambari官方文档 hadoop 2.0 详细配置教程 使用Ambari快速部署Hadoop大 ...

  5. 杭电hdu-6168 Numbers

    这一题是考察排序与后续数据处理的题.我是用了map来给“和”做标记,把确定为a数组内数的数两两求和.给这些和标记,这样就可以很好的处理带有重复数的数据了~~ 贴个碼: #include<iost ...

  6. awk详解2

    7.控制语句 if(condition) {statments} 单分支语句 if(condition) {statments} else {statements}组合语句 while(condito ...

  7. BOM - 浏览器API

     1,javascript   组成部分: 1.ECMAscript(核心标准):    定义了基本的语法,比如:if for 数组 字符串 ... 2.BOM  : 浏览器对象模型(Browser ...

  8. 创建 JavaScript 类和对象 prototype

    创建 JavaScript 对象 通过 JavaScript,您能够定义并创建自己的对象. 创建新对象有两种不同的方法: 定义并创建对象的实例(直接创建方式) person=new Object(); ...

  9. 根据元素取两个list<T>不同

    var aa = ltB.FindAll(b => ltA.Any(a => a.PolicyNo == b.ID)); //得出不同 var expectedList = ltB.Exc ...

  10. 【Ruby】【目录 & 引用 & 文件 】

    [[目录]] 当前文件在根目录下一个文件夹下 引用当前文件所在目录上一级目录下某.rb文件 方法一 require File.join(File.dirname(FILE),'..','test_on ...