DRF 学习

一、安装DRF

1、pip install djangorestframework -i https://pypi.douban.com/simple

2、pip install pymysql -i https://pypi.douban.com/simple

二、创建Django项目

1、django-admin startproject drfdemo

三、添加rest_framework应用

1、INSTALLED_APPS = [

...

'rest_framework',

]

四、创建模型操作类

1、创建模型操作类

python 复制代码
class Student(models.Model):
    # 模型字段
    name = models.CharField(max_length=100,verbose_name="姓名")
    sex = models.BooleanField(default=1,verbose_name="性别")
    age = models.IntegerField(verbose_name="年龄")
    class_null = models.CharField(max_length=5,verbose_name="班级编号")
    description = models.TextField(max_length=1000,verbose_name="个性签名")

    class Meta:
        db_table="tb_student"
        verbose_name = "学生"
        verbose_name_plural = verbose_name

2、创建数据库 create database students charset=utf8;

3、执行数据迁移 把app01增加到INSTALL_APPS中

4、在__init__.py中增加pymysql做为数据库驱动

import pymysql

pymysql.version_info = (1, 4, 13, "final", 0)

pymysql.install_as_MySQLdb()

5、在setting.py配置文件中设置mysql的账号密码

python 复制代码
    DATABASES = {
   # 'default': {
   #     'ENGINE': 'django.db.backends.sqlite3',
   #     'NAME': BASE_DIR / 'db.sqlite3',
   # }
    'default':{
        'ENGINE':'django.db.backends.mysql',
        'NAME': "students",
        "HOST": "127.0.0.1",
        "PORT": 3306,
        "USER": "root",
        "PASSWORD": "123456"
    }
}

6、终端命令下执行数据迁移

python manage.py migrate #创建表结构

python manage.py makemigrations app01#让Django知道模型有一些变更 注意是app01 应用名称,不是项目名称

python manage.py migrate app01 #创建表结构 注意是app01 应用名称,不是项目名称

7、在app01中新建serializers.py用于保存应用的序列化器。

创建序列化器类,回头会在试图中被调用 创建一个StudentModelSerializer用于序列化与反序列化。

python 复制代码
    class StudentModelSerializer(serializers.ModelSerializer):
            class Meta:
                    model = Student
                    fields = "__all__"

8、编写视图类

在app01应用的views.py中创建视图StudentViewSet,这是一个视图集合。

python 复制代码
    from django.shortcuts import render
    from rest_framework.viewsets import ModelViewSet
    from .models import Student
    from .serializers import StudentModelSerializer


    # Create your views here.
    class StudentViewSet(ModelViewSet):
            queryset = Student.objects.all()
            serializer_class = StudentModelSerializer

#queryset 指明该视图集在查询数据时使用的查询集

#serializer_class 指明该视图在进行序列化或反序列化时使用的序列化器9、定义路由

新建urls.py 添加路由信息

python 复制代码
    from . import views
    from rest_framework.routers import DefaultRouter

    #路由列表
    urlpatterns = []

    router = DefaultRouter() #可以处理视图的路由
    router.register('student',views.StudentViewSet) #像路由器中注册视图集

    urlpatterns += router.urls  #将路由器中的所有路由追加到django的路由列表中

    把students子应用中的路由文件加载到总路由中
    
    from django.contrib import admin
    from django.conf.urls import url
    from django.urls import path
    from django.urls import include
    from . import  views

    urlpatterns = [
            #path('admin/', admin.site.urls),
            #url(r'^$',views.hello),
            path('',views.hello), #http://127.0.0.1:8000/hello/
            path('print',views.print),  #http://127.0.0.1:8000/print
            path('templates',views.templates),
            path("stu/",include("app01.urls")),
    ]

点击链接127.0.0.1:8000/stu/students获取所有数据

相关推荐
鸡鸭扣1 小时前
Docker:3、在VSCode上安装并运行python程序或JavaScript程序
运维·vscode·python·docker·容器·js
库库林_沙琪马1 小时前
Redis 持久化:从零到掌握
数据库·redis·缓存
paterWang1 小时前
基于 Python 和 OpenCV 的酒店客房入侵检测系统设计与实现
开发语言·python·opencv
东方佑2 小时前
使用Python和OpenCV实现图像像素压缩与解压
开发语言·python·opencv
饮长安千年月2 小时前
Linksys WRT54G路由器溢出漏洞分析–运行环境修复
网络·物联网·学习·安全·机器学习
红花与香菇2____2 小时前
【学习笔记】Cadence电子设计全流程(二)原理图库的创建与设计(上)
笔记·嵌入式硬件·学习·pcb设计·cadence·pcb工艺
神秘_博士2 小时前
自制AirTag,支持安卓/鸿蒙/PC/Home Assistant,无需拥有iPhone
arm开发·python·物联网·flutter·docker·gitee
牵牛老人2 小时前
Qt中使用QPdfWriter类结合QPainter类绘制并输出PDF文件
数据库·qt·pdf
Moutai码农3 小时前
机器学习-生命周期
人工智能·python·机器学习·数据挖掘
卡西里弗斯奥4 小时前
【达梦数据库】dblink连接[SqlServer/Mysql]报错处理
数据库·mysql·sqlserver·达梦