当前位置: 首页 > ds >正文

Django REST Framework 入门指南:从 0 到 1 实现 RESTful API

目录

一、RESTful API 与 DRF 简介

二、环境搭建与初始化

三、核心步骤:实现基础 CRUD 接口

1. 定义数据模型(models.py)

2. 创建序列化器(serializers.py)

3. 编写视图(views.py)

4. 配置 URL 路由

四、启动与测试

五、总结


在前后端分离架构日益普及的今天,构建一套规范、高效的 API 接口成为后端开发的核心任务。Django REST Framework(DRF)作为基于 Django 的强大工具包,能快速实现符合 RESTful 规范的 API,本文将带你从 0 开始,一步步搭建完整的增删改查接口。

一、RESTful API 与 DRF 简介

RESTful API 是一种软件架构风格,通过 HTTP 方法(GET/POST/PUT/DELETE)对资源进行操作,具有无状态、可缓存等特点。DRF 则是 Django 生态中用于构建 RESTful API 的利器,它提供了序列化、认证、权限控制等功能,让开发者无需重复造轮子。

二、环境搭建与初始化
  1. 创建项目与应用

    django-admin startproject myproject
    cd myproject
    python manage.py startapp stuapi  # 新建API应用
    
  2. 安装依赖

    pip install djangorestframework  # 安装DRF
    
  3. 配置 settings.py
    INSTALLED_APPS中添加rest_frameworkstuapi

    INSTALLED_APPS = [# ...其他应用'rest_framework','stuapi',
    ]
    
三、核心步骤:实现基础 CRUD 接口

以 “学生信息管理” 为例,实现完整的 API 功能。

1. 定义数据模型(models.py)
from django.db import modelsclass Student(models.Model):name = models.CharField(max_length=100, verbose_name="姓名")age = models.IntegerField(verbose_name="年龄")sex = models.BooleanField(default=True, verbose_name="性别")classmate = models.CharField(max_length=50, verbose_name="班级")class Meta:verbose_name = "学生"verbose_name_plural = verbose_name

执行数据迁移:

python manage.py makemigrations
python manage.py migrate
2. 创建序列化器(serializers.py)

序列化器负责数据的转换(模型对象→JSON)和验证,新建stuapi/serializers.py

from rest_framework import serializers
from .models import Studentclass StudentSerializer(serializers.ModelSerializer):# 自动映射模型字段,简化代码class Meta:model = Studentfields = "__all__"  # 序列化所有字段read_only_fields = ["id"]  # id字段只读(自动生成)
3. 编写视图(views.py)

使用 DRF 的ModelViewSet快速实现 CRUD:

from rest_framework.viewsets import ModelViewSet
from .models import Student
from .serializers import StudentSerializerclass StudentViewSet(ModelViewSet):queryset = Student.objects.all()  # 查询集serializer_class = StudentSerializer  # 关联序列化器
4. 配置 URL 路由
  • 子路由(stuapi/urls.py)

    from django.urls import path, include
    from rest_framework.routers import DefaultRouter
    from .views import StudentViewSetrouter = DefaultRouter()  # 自动生成路由
    router.register(r'students', StudentViewSet)  # 注册视图集urlpatterns = [path('', include(router.urls)),
    ]
    
  • 主路由(myproject/urls.py)

    from django.contrib import admin
    from django.urls import path, includeurlpatterns = [path('admin/', admin.site.urls),path('api/', include('stuapi.urls')),  # 挂载API路由
    ]
    
四、启动与测试

运行项目:

python manage.py runserver

访问http://127.0.0.1:8000/api/students/,即可看到 DRF 自动生成的可视化接口页面,支持通过表单或 JSON 格式进行:

  • GET:查询学生列表或单个学生
  • POST:新增学生
  • PUT/PATCH:更新学生信息
  • DELETE:删除学生
五、总结

DRF 通过 “序列化器 + 视图集 + 路由” 的组合,极大简化了 RESTful API 的开发流程。只需几行代码,就能实现完整的增删改查功能,且自带可视化调试界面,非常适合快速迭代开发。下一篇将深入讲解序列化器的高级用法,敬请关注。

http://www.xdnf.cn/news/15679.html

相关文章:

  • Linux-局域网构建+VLAN 划分 + 端口 MAC-IP 绑定 + 静态 DHCP
  • Python 进阶学习之全栈开发学习路线
  • 如何删除 VSCode 账号的远程同步备份记录数据
  • 如何使用VScode使用ssh连接远程服务器不需要输入密码直接登录
  • 信息收集知识总结
  • LabVIEW液压机智能监控
  • gem install报错解析
  • 【C# in .NET】11. 探秘泛型:类型参数化革命
  • JAVA面试宝典 -《分布式ID生成器:Snowflake优化变种》
  • 基于CentOS的分布式GitLab+Jenkins+Docker架构:企业级CI/CD流水线实战全记录
  • 基于 Spring Boot 构建的文件摆渡系统(File Ferry System)
  • 更灵活方便的初始化、清除方法——fixture【pytest】
  • AWS WebRTC 并发 Viewer 拉流失败分析:0.3 秒等待为何如此关键?
  • 消息转换器--通过此工具进行时间转换
  • Mybatis-2快速入门
  • 【WRFDA数据教程第一期】LITTLE_R 格式详细介绍
  • 【源力觉醒 创作者计划】百度携文心 4.5 入局,开源大模型市场再添一员猛将,与 Qwen3 对比如何?
  • 3DGS之COLMAP
  • iOS 抓包工具选择与配置指南 从零基础到高效调试的完整流程
  • Android动态获取当前应用占用的内存PSS,Java
  • 汽车功能安全-相关项集成和测试(系统集成测试系统合格性测试)-12
  • 从电子管到CPU
  • 迁移学习的概念和案例
  • 【前端Vue】this.resetForm(“form“)重置表单时出现indexOf报错的解决方案
  • Java 增强 switch 语句详解:从基础到进阶的全面指南
  • Sersync和Rsync部署
  • Ubuntu 安装
  • 22-C#的委托简单使用-2
  • Linux715 磁盘管理:逻辑卷
  • MyBatis Plus功能增强全解析:从手写SQL到优雅开发的进阶指南