news 2026/4/16 7:39:47

Django REST Framework项目最佳实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Django REST Framework项目最佳实践

Django REST Framework(DRF)是构建高质量 Web API 的强大工具,但初学者常因项目结构混乱、配置冗余或缺乏规范而难以发挥其全部潜力。本文提供了一个小但完整的 DRF 示例项目,旨在展示现代 Django API 开发中推荐的组织方式与工程实践。

一、项目结构

最终项目目录结构如下:

myproject/ ├── venv/ # 虚拟环境 ├── requirements.txt # 依赖清单 ├── manage.py ├── myproject/ │ ├── __init__.py │ ├── settings.py │ ├── urls.py │ └── wsgi.py ├── myapp/ │ ├── __init__.py │ ├── models.py # 数据模型 │ ├── serializers.py # 序列化器 │ ├── views.py # 视图逻辑 │ ├── parsers.py # JSONL 解析函数 │ ├── urls.py # 应用路由 │ ├── tests.py # 单元测试 │ └── static/ # 本地图片(实际可能在云端) │ └── images/ │ ├── img1.jpg │ └── img2.png └── api.http # HTTP 接口测试文件

二、环境准备与依赖安装

1. 创建项目目录并进入

django-admin startproject myprojectcdmyproject

2. 创建虚拟环境

python -m venv venvsourcevenv/bin/activate# Linux/macOS# source venv\Scripts\activate # Windows bash

3. 安装依赖

创建requirements.txt文件:

Django==5.2 djangorestframework==3.16.0

安装:

pipinstall-r requirements.txt

4. 创建应用

python manage.py startapp myapp

三、配置

编辑myproject/settings.py

frompathlibimportPath BASE_DIR=Path(__file__).resolve().parent.parent SECRET_KEY='django-insecure-z1*txrg&y@f^for5@+&8%3pq)^i&by!*riz9i=837=n(pdbyfh'DEBUG=TrueALLOWED_HOSTS=[]INSTALLED_APPS=['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','myapp.apps.MyappConfig','rest_framework','rest_framework.authtoken',# 启用 Token 认证]MIDDLEWARE=['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware','django.middleware.csrf.CsrfViewMiddleware','django.contrib.auth.middleware.AuthenticationMiddleware','django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',]ROOT_URLCONF='myproject.urls'TEMPLATES=[{'BACKEND':'django.template.backends.django.DjangoTemplates','DIRS':[BASE_DIR/'templates'],'APP_DIRS':True,'OPTIONS':{'context_processors':['django.template.context_processors.request','django.contrib.auth.context_processors.auth','django.contrib.messages.context_processors.messages',],},},]WSGI_APPLICATION='myproject.wsgi.application'DATABASES={'default':{'ENGINE':'django.db.backends.sqlite3','NAME':BASE_DIR/'db.sqlite3',}}AUTH_PASSWORD_VALIDATORS=[{'NAME':'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',},{'NAME':'django.contrib.auth.password_validation.MinimumLengthValidator',},{'NAME':'django.contrib.auth.password_validation.CommonPasswordValidator',},{'NAME':'django.contrib.auth.password_validation.NumericPasswordValidator',},]LANGUAGE_CODE='en-us'TIME_ZONE='UTC'USE_I18N=TrueUSE_TZ=TrueSTATIC_URL='static/'# DRF 配置REST_FRAMEWORK={'DEFAULT_AUTHENTICATION_CLASSES':['rest_framework.authentication.TokenAuthentication',],'DEFAULT_PERMISSION_CLASSES':['rest_framework.permissions.IsAuth
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/8 18:17:06

3个核心优势的自动化工具:技术探索者的效率提升指南

3个核心优势的自动化工具:技术探索者的效率提升指南 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 如何解决高频抢单场景下的人工操作局限? 在电商促销、限量商品发售等…

作者头像 李华
网站建设 2026/4/3 21:25:22

解锁Minecraft启动器新境界:打造专属游戏入口的全方位指南

解锁Minecraft启动器新境界:打造专属游戏入口的全方位指南 【免费下载链接】PCL2-CE PCL2 社区版,可体验上游暂未合并的功能 项目地址: https://gitcode.com/gh_mirrors/pc/PCL2-CE 在充满无限创造力的方块世界里,一个能够完美适配个人…

作者头像 李华
网站建设 2026/3/31 3:47:00

番茄小说下载器:电子书制作全流程工具详解

番茄小说下载器:电子书制作全流程工具详解 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 电子书制作已成为数字阅读时代的必备技能,而番茄小说下载器作…

作者头像 李华
网站建设 2026/4/7 13:21:56

kNN-LMs揭秘:如何通过记忆机制提升语言模型的泛化能力

1. 什么是kNN-LMs?从记忆机制看语言模型进化 如果你用过ChatGPT这类大语言模型,可能会发现一个有趣现象:它们有时候能准确回答冷门问题,却会在简单常识上翻车。这背后其实反映了当前语言模型的一个根本矛盾——模型到底是靠"…

作者头像 李华
网站建设 2026/4/2 5:07:52

3步破解法:JetBrains IDE激活工具实现永久使用全攻略

3步破解法:JetBrains IDE激活工具实现永久使用全攻略 【免费下载链接】ide-eval-resetter 项目地址: https://gitcode.com/gh_mirrors/id/ide-eval-resetter JetBrains IDE激活一直是开发者关注的焦点,当30天试用期结束,面对高昂的授…

作者头像 李华