news 2026/6/10 17:13:50

python在Django中实现文件上传功能步骤

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
python在Django中实现文件上传功能步骤

你想了解在 Django 框架中实现文件上传功能的核心步骤,需要一份清晰、可落地的步骤指南,涵盖从配置到代码实现的全流程。以下是 Django 实现文件上传的 7 个核心步骤,每个步骤都包含具体配置和代码示例,适配 Django 4.x/5.x 版本。


Django 实现文件上传的核心步骤

步骤 1:配置媒体文件(Media)路径(基础前提)

Django 中上传的文件默认存储在媒体文件目录(Media),需要在settings.py中配置路径和访问 URL,这是文件上传的基础。

配置代码(settings.py)

python

# 项目根目录(拼接路径用) import os BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # 1. 媒体文件存储路径(上传的文件会存到这个目录) MEDIA_ROOT = os.path.join(BASE_DIR, 'media') # 项目根目录下的media文件夹 # 2. 媒体文件访问URL(前端/后端访问上传文件的URL前缀) MEDIA_URL = '/media/' # 例如:http://127.0.0.1:8000/media/xxx.jpg # 可选:文件上传大小限制(防止超大文件上传) DATA_UPLOAD_MAX_MEMORY_SIZE = 10485760 # 10MB(默认2.5MB) FILE_UPLOAD_MAX_MEMORY_SIZE = 10485760 # 10MB
关键说明
  • MEDIA_ROOT:本地物理路径,必须是绝对路径,Django 会把上传的文件保存到这个目录;
  • MEDIA_URL:URL 路径,用于浏览器访问上传的文件(比如上传的图片可以通过http://域名/media/文件名访问);
  • 需手动在项目根目录创建media文件夹(否则上传时会报路径不存在错误)。

步骤 2:配置 URL 以访问媒体文件(可选但必要)

开发环境下,需要配置 URL 路由,让 Django 能处理MEDIA_URL的访问请求(生产环境需用 Nginx 等服务器处理)。

配置代码(项目根 urls.py)

python

from django.contrib import admin from django.urls import path from django.conf import settings from django.conf.urls.static import static urlpatterns = [ path('admin/', admin.site.urls), # 其他路由... ] # 开发环境下,添加媒体文件的访问路由 if settings.DEBUG: urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

步骤 3:定义包含文件字段的模型(Model)(可选,按需使用)

如果需要将文件信息(如文件名、存储路径)存入数据库,需在models.py中定义模型,核心字段是FileField(通用文件)或ImageField(图片文件,需安装Pillow)。

模型代码(app/models.py)

python

from django.db import models class UploadFile(models.Model): # 1. 文件字段:upload_to指定文件存储的子目录(media下的uploads文件夹) file = models.FileField(upload_to='uploads/%Y/%m/%d/') # 按年月日分目录存储 # 可选:图片字段(需安装Pillow:pip install Pillow) # image = models.ImageField(upload_to='images/%Y/%m/%d/') # 2. 上传时间(自动记录) upload_time = models.DateTimeField(auto_now_add=True) # 可选:自定义文件名显示 def __str__(self): return self.file.name
关键说明
  • upload_to:可以是字符串(固定目录)或函数(动态生成目录 / 文件名);
  • 执行python manage.py makemigrationspython manage.py migrate创建数据库表。

步骤 4:创建文件上传表单(Form)(简化验证)

使用 Django 的表单类(Form/ModelForm)可以自动验证文件类型、大小,简化处理逻辑。

表单代码(app/forms.py)

python

from django import forms from .models import UploadFile # 方式1:ModelForm(关联模型,推荐) class UploadFileForm(forms.ModelForm): class Meta: model = UploadFile fields = ['file'] # 对应模型中的字段 # 可选:添加表单样式/验证 widgets = { 'file': forms.ClearableFileInput(attrs={'class': 'form-control'}), } # 方式2:普通Form(不关联模型) # class UploadFileForm(forms.Form): # file = forms.FileField(label='选择文件', widget=forms.ClearableFileInput)

步骤 5:编写视图函数 / 类(View)处理上传逻辑(核心)

视图是处理文件上传的核心,负责接收请求、验证表单、保存文件,分为函数视图类视图两种方式。

方式 1:函数视图(简单易理解)

python

from django.shortcuts import render, redirect from .forms import UploadFileForm def file_upload(request): if request.method == 'POST': # 1. 绑定表单数据(包含文件) form = UploadFileForm(request.POST, request.FILES) if form.is_valid(): # 2. 保存文件(ModelForm会自动保存到MEDIA_ROOT指定的路径) form.save() # 3. 上传成功,跳转/提示 return render(request, 'upload_success.html', {'msg': '文件上传成功!'}) else: # GET请求,显示空表单 form = UploadFileForm() return render(request, 'upload.html', {'form': form})
方式 2:类视图(Django 推荐,更简洁)

python

from django.views.generic import FormView from django.urls import reverse_lazy from .forms import UploadFileForm class FileUploadView(FormView): template_name = 'upload.html' # 上传页面模板 form_class = UploadFileForm # 绑定的表单类 success_url = reverse_lazy('upload_success') # 上传成功后的跳转URL # 重写form_valid方法,处理文件保存 def form_valid(self, form): form.save() # 保存文件 return super().form_valid(form)
关键说明
  • 文件上传必须用POST请求,且表单enctype需为multipart/form-data
  • request.FILES:Django 封装的文件数据,必须传入表单才能获取上传的文件;
  • form.is_valid():自动验证文件是否符合要求(如大小、类型)。

步骤 6:编写前端上传页面(HTML 模板)

创建模板文件,显示表单并支持文件选择和提交。

模板代码(templates/upload.html)

html

预览

<!DOCTYPE html> <html> <head> <title>文件上传</title> </head> <body> <h1>文件上传</h1> <!-- 必须设置enctype="multipart/form-data"才能上传文件 --> <form method="post" enctype="multipart/form-data"> {% csrf_token %} <!-- Django必加,防止CSRF攻击 --> {{ form.as_p }} <!-- 渲染表单 --> <button type="submit">上传</button> </form> </body> </html>
成功页面(templates/upload_success.html)

html

预览

<!DOCTYPE html> <html> <head> <title>上传成功</title> </head> <body> <h1>{{ msg }}</h1> <a href="{% url 'file_upload' %}">返回上传页面</a> </body> </html>

步骤 7:配置 URL 路由(映射视图)

将视图映射到 URL,让用户可以访问上传页面。

路由代码(app/urls.py)

python

from django.urls import path from . import views urlpatterns = [ # 函数视图路由 path('upload/', views.file_upload, name='file_upload'), # 类视图路由(如果用类视图) # path('upload/', views.FileUploadView.as_view(), name='file_upload'), # 成功页面路由 path('upload/success/', lambda request: render(request, 'upload_success.html'), name='upload_success'), ]

步骤 8:测试文件上传功能

  1. 启动 Django 开发服务器:python manage.py runserver
  2. 访问http://127.0.0.1:8000/upload/
  3. 选择文件并点击 “上传”,成功后会看到提示,且media/uploads/目录下会出现上传的文件。

进阶注意事项(生产环境必备)

  1. 文件类型验证:限制仅允许上传指定类型的文件(如.pdf.jpg):

    python

    # 在forms.py中添加验证 def clean_file(self): file = self.cleaned_data['file'] allowed_extensions = ['pdf', 'jpg', 'png', 'txt'] extension = file.name.split('.')[-1].lower() if extension not in allowed_extensions: raise forms.ValidationError('仅允许上传PDF、JPG、PNG、TXT文件!') return file
  2. 文件重命名:避免文件名重复,自定义文件名:

    python

    # 在models.py中自定义upload_to函数 def custom_upload_to(instance, filename): import uuid ext = filename.split('.')[-1] new_filename = f"{uuid.uuid4()}.{ext}" # 用UUID生成唯一文件名 return f'uploads/{new_filename}' # 模型字段修改 file = models.FileField(upload_to=custom_upload_to)
  3. 生产环境配置
    • 不要用 Django 处理媒体文件访问,改用 Nginx/Apache;
    • 可将文件存储到云存储(如阿里云 OSS、腾讯云 COS),需安装对应插件(如django-storages)。

总结

  1. Django 文件上传的核心是配置 Media 路径(存储 + 访问)、表单验证文件视图处理保存三大环节;
  2. 关键要点:表单必须设置enctype="multipart/form-data",视图需接收request.FILES,开发环境需配置 Media URL;
  3. 生产环境需增加文件类型 / 大小验证、自定义文件名、改用第三方存储 / 服务器处理文件访问。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 15:21:32

PyTorch + CUDA 11.8 在Miniconda环境中的安装步骤

PyTorch CUDA 11.8 在 Miniconda 环境中的安装与实践 在深度学习项目中&#xff0c;一个稳定、可复现且能充分发挥硬件性能的开发环境至关重要。许多工程师都曾经历过“在我机器上能跑”的尴尬局面——问题往往不在于代码&#xff0c;而在于环境配置的细微差异。尤其是当涉及…

作者头像 李华
网站建设 2026/6/10 9:31:28

Miniconda如何避免pip与conda混用导致PyTorch崩溃

Miniconda 如何避免 pip 与 conda 混用导致 PyTorch 崩溃 在深度学习项目中&#xff0c;你是否曾遇到过这样的场景&#xff1a;明明昨天还能正常训练的模型&#xff0c;今天一运行就报错 ImportError: libcudart.so.11.0: cannot open shared object file&#xff1f;或者 CUDA…

作者头像 李华
网站建设 2026/6/10 2:19:01

[STM32C0] 【STM32C092RC 测评】+简单的按键控制led亮灭

如果之前的配置比较熟悉的话&#xff0c;直接看这个图应该知道怎么配置的&#xff1a;因为这个没有用到中断和回调函数 主要是在while中添加对应的处理逻辑&#xff1a; 下面看代码&#xff1a;复制/* USER CODE BEGIN WHILE */ while (1) { if(HAL_GPIO_ReadPin(BT…

作者头像 李华
网站建设 2026/6/4 2:09:54

Miniconda-Python3.9镜像支持弹性伸缩GPU实例

Miniconda-Python3.9镜像支持弹性伸缩GPU实例 在AI模型训练日益复杂的今天&#xff0c;一个常见的场景是&#xff1a;研究员在本地调试完代码后上传到云端&#xff0c;却发现“在我机器上明明能跑”的脚本在集群中报错——原因往往是CUDA版本不匹配、依赖库冲突&#xff0c;或是…

作者头像 李华
网站建设 2026/6/1 2:32:02

如何用Obsidian-Douban插件构建个人娱乐知识库?

如何用Obsidian-Douban插件构建个人娱乐知识库&#xff1f; 【免费下载链接】obsidian-douban an obsidian plugin that can pull data from douban to your markdown file 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-douban 你是否曾经为了整理自己的观影记…

作者头像 李华