news 2026/4/16 11:08:34

搭建一个基于Django框架的WebApi项目

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
搭建一个基于Django框架的WebApi项目

搭建一个基于Django框架的WebApi项目

Django是一个强大的Python Web框架,以其“快速开发”和“不要重复自己”的原则闻名。到2026年,Django 5.x已成为主流版本,集成更强的异步支持和安全特性。本教程从零指导您搭建一个基于Django的Web API项目,使用Django REST Framework(DRF)实现RESTful API。示例项目:一个简单的“书籍管理”API,支持CRUD操作。整个过程基于Python 3.12+和Django 5.0+,适合初学者到中级开发者。

前提:确保您有Python环境(推荐虚拟环境)。如果没有,安装Python并用pip install virtualenv创建虚拟环境。

1. 环境准备

步骤1:创建虚拟环境

# 创建项目目录mkdirdjango_api_projectcddjango_api_project# 创建并激活虚拟环境(Windows用Scripts\activate)python -m venv venvsourcevenv/bin/activate# Linux/Mac# 升级pippipinstall--upgrade pip

步骤2:安装依赖

Django REST Framework是构建API的核心库。

pipinstalldjango djangorestframework

步骤3:创建Django项目

django-admin startproject book_api.
  • book_api:项目名。
  • .:在当前目录创建。

项目结构:

book_api/ ├── manage.py └── book_api/ ├── __init__.py ├── asgi.py ├── settings.py ├── urls.py └── wsgi.py

2. 创建应用(App)

API功能放在一个App中。

python manage.py startapp books
  • books:App名。

添加App到settings.pyINSTALLED_APPS

# book_api/settings.pyINSTALLED_APPS=[...'rest_framework',# 添加DRF'books.apps.BooksConfig',# 添加您的App]

3. 定义模型(Models)

books/models.py中定义Book模型。

# books/models.pyfromdjango.dbimportmodelsclassBook(models.Model):title=models.CharField(max_length=200)author=models.CharField(max_length=100)published_date=models.DateField()description=models.TextField(blank=True)def__str__(self):returnself.title

迁移数据库

python manage.py makemigrations python manage.py migrate

4. 配置序列化器(Serializers)

DRF用序列化器将模型转为JSON。
books/serializers.py创建:

# books/serializers.pyfromrest_frameworkimportserializersfrom.modelsimportBookclassBookSerializer(serializers.ModelSerializer):classMeta:model=Book fields='__all__'# 或指定字段如 ['id', 'title', 'author']

5. 创建视图(Views)

使用DRF的ViewSet简化CRUD。
books/views.py

# books/views.pyfromrest_frameworkimportviewsetsfrom.modelsimportBookfrom.serializersimportBookSerializerclassBookViewSet(viewsets.ModelViewSet):queryset=Book.objects.all()serializer_class=BookSerializer

6. 配置URL路由

项目级urls.py

# book_api/urls.pyfromdjango.contribimportadminfromdjango.urlsimportpath,includefromrest_framework.routersimportDefaultRouterfrombooks.viewsimportBookViewSet router=DefaultRouter()router.register(r'books',BookViewSet)urlpatterns=[path('admin/',admin.site.urls),path('api/',include(router.urls)),# API根路径]

7. 配置REST Framework

settings.py添加DRF设置(可选,默认即可):

# book_api/settings.pyREST_FRAMEWORK={'DEFAULT_PAGINATION_CLASS':'rest_framework.pagination.PageNumberPagination','PAGE_SIZE':10,# 分页大小}

8. 运行与测试

启动服务器

python manage.py runserver
  • 访问:http://127.0.0.1:8000/api/books/ (浏览器显示DRF界面)。

创建超级用户(可选,管理后台)

python manage.py createsuperuser
  • 访问/admin/添加书籍数据。

测试API

用Postman或curl:

  • GET /api/books/:列出所有书籍。
  • POST /api/books/:创建书籍(JSON: {“title”: “Django Book”, “author”: “Author”, “published_date”: “2026-01-01”})。
  • PUT /api/books/1/:更新ID=1的书籍。
  • DELETE /api/books/1/:删除。

9. 优化与高级配置

  • 认证与权限:在settings.py添加DEFAULT_AUTHENTICATION_CLASSES,如JWT或Token。
    REST_FRAMEWORK={...'DEFAULT_AUTHENTICATION_CLASSES':['rest_framework.authentication.BasicAuthentication','rest_framework.authentication.SessionAuthentication',],'DEFAULT_PERMISSION_CLASSES':['rest_framework.permissions.IsAuthenticated',]}
  • 异步支持:Django 5.x用ASGI(asgi.py),集成Celery处理后台任务。
  • 部署:用Gunicorn + Nginx,数据库用PostgreSQL生产级。
  • 安全:启用CORS(pip install django-cors-headers),配置ALLOWED_HOSTS。
  • 文档:用DRF的Swagger(pip install drf-yasg),添加URL。

10. 常见问题排查

  • No migrations:运行makemigrationsmigrate
  • API 404:检查urls.py路由。
  • 序列化错误:确保模型字段匹配。
  • 性能:大项目用缓存(Redis)和分页。

通过这个项目,您已掌握Django API基础。建议扩展:添加用户认证、过滤器(search_fields)。如果需要完整代码或特定功能,欢迎评论交流~ 😄

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:03:34

小白必看!Qwen2.5-0.5B保姆级部署教程,轻松玩转大模型

小白必看!Qwen2.5-0.5B保姆级部署教程,轻松玩转大模型 1. 认识 Qwen2.5-0.5B:轻量级大模型的全能选手 1.1 模型背景与定位 Qwen2.5 是阿里云通义千问团队推出的最新一代大语言模型系列,覆盖从 0.5B 到 720B 的多个参数规模。其…

作者头像 李华
网站建设 2026/4/16 11:03:38

GetQzonehistory完整教程:如何永久保存QQ空间所有历史记录

GetQzonehistory完整教程:如何永久保存QQ空间所有历史记录 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否担心那些记录青春时光的QQ空间说说会随时间消失&#xff1f…

作者头像 李华
网站建设 2026/4/16 9:23:12

HunyuanVideo-Foley从零开始:视频音效自动化的最新解决方案

HunyuanVideo-Foley从零开始:视频音效自动化的最新解决方案 随着AI生成技术的不断演进,音视频内容创作正迎来一场效率革命。传统视频后期制作中,音效添加往往依赖人工逐帧匹配,耗时耗力且对专业能力要求高。2025年8月28日&#x…

作者头像 李华
网站建设 2026/4/16 10:58:45

AI隐私保护实战教程:绿色安全框标记技术详解

AI隐私保护实战教程:绿色安全框标记技术详解 1. 引言:AI 人脸隐私卫士 - 智能自动打码 在人工智能与图像处理技术飞速发展的今天,个人隐私保护正面临前所未有的挑战。尤其是在社交媒体、公共监控、企业文档共享等场景中,未经脱敏…

作者头像 李华
网站建设 2026/4/16 9:21:41

FictionDown完整教程:多源小说下载与格式转换终极指南

FictionDown完整教程:多源小说下载与格式转换终极指南 【免费下载链接】FictionDown 小说下载|小说爬取|起点|笔趣阁|导出Markdown|导出txt|转换epub|广告过滤|自动校对 项目地址: https://gitcode.com/gh_mirrors/fi/FictionDown FictionDown是一款专业的命…

作者头像 李华
网站建设 2026/4/16 9:26:11

GLM-4.6V-Flash-WEB部署实战:网页端交互系统搭建步骤

GLM-4.6V-Flash-WEB部署实战:网页端交互系统搭建步骤 智谱最新开源,视觉大模型。 1. 背景与应用场景 1.1 视觉大模型的演进趋势 近年来,多模态大模型在图文理解、视觉问答(VQA)、图像描述生成等任务中展现出强大能力…

作者头像 李华