当前位置:首页 > 技术 > 正文内容

Django 4 静态资源与媒体文件配置实践

访客 技术 2026年6月25日 1

在 Django 4 项目中,静态资源(CSS、JavaScript、图片等)和用户上传的媒体文件需要分别配置独立的管理策略。以下从配置项设置、开发环境调试到生产环境部署进行完整说明。

静态文件配置

编辑 settings.py 文件,添加以下配置:

import os
from pathlib import Path

# 项目根目录
PROJECT_ROOT = Path(__file__).resolve().parent.parent

# 静态文件 URL 前缀
STATIC_URL = '/assets/'

# 开发阶段:Django 查找静态文件的额外目录
STATICFILES_DIRS = [
    os.path.join(PROJECT_ROOT, 'assets'),
]

# 生产阶段:collectstatic 命令收集目标目录
STATIC_ROOT = os.path.join(PROJECT_ROOT, 'collected_static')

关键区别说明:

  • STATICFILES_DIRS:开发时使用的源文件目录列表,支持多个路径
  • STATIC_ROOT:部署前执行收集命令的统一输出目录

生产环境收集命令:

python manage.py collectstatic --noinput

媒体文件配置

用户上传的内容(头像、附件等)需单独配置:

# 媒体文件访问 URL
MEDIA_URL = '/uploads/'

# 媒体文件本地存储绝对路径
MEDIA_ROOT = os.path.join(PROJECT_ROOT, 'upload_storage')

路由配置(仅开发环境)

修改主路由文件 urls.py,添加调试模式下的文件服务:

from django.conf import settings
from django.conf.urls.static import static
from django.urls import path

urlpatterns = [
    # 业务路由...
]

# 开发环境:由 Django 直接托管静态与媒体文件
if settings.DEBUG:
    urlpatterns += static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
    urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

生产环境务必关闭此配置,改用 Nginx 等反向代理直接处理静态请求。

模板中引用静态文件

确保模板继承结构中使用正确的加载标签:

{% load static %}

<!DOCTYPE html>
<html>
<head>
    <link rel="stylesheet" href="{% static 'styles/main.css' %}">
</head>
<body>
    <img src="{% static 'images/logo.png' %}" alt="Logo">
    
    <script src="{% static 'scripts/app.js' %}"></script>
</body>
</html>

集成 Bootstrap 4.6 示例

以前端框架集成为例,演示完整静态资源管理流程:

目录结构准备:

assets/
├── css/
│   └── bootstrap.min.css
├── js/
│   ├── jquery-3.6.0.min.js
│   └── bootstrap.bundle.min.js
└── fonts/
    └── (字体文件)

Bootstrap 4.6 依赖 jQuery 3.x,加载顺序至关重要。基础模板 base.html

{% load static %}
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>{% block title %}My Site{% endblock %}</title>
    
    <link rel="stylesheet" href="{% static 'css/bootstrap.min.css' %}">
    {% block extra_css %}{% endblock %}
</head>
<body>
    <nav class="navbar navbar-expand-lg navbar-dark bg-dark">
        <div class="container">
            <a class="navbar-brand" href="/">项目首页</a>
        </div>
    </nav>
    
    <main class="container mt-4">
        {% block content %}{% endblock %}
    </main>
    
    <!-- 脚本加载顺序:jQuery 必须在 Bootstrap 之前 -->
    <script src="{% static 'js/jquery-3.6.0.min.js' %}"></script>
    <script src="{% static 'js/bootstrap.bundle.min.js' %}"></script>
    {% block extra_js %}{% endblock %}
</body>
</html>

注意使用 bootstrap.bundle.min.js 已内置 Popper.js,无需单独引入。

生产环境部署要点

Nginx 配置示例片段:

location /assets/ {
    alias /var/www/myproject/collected_static/;
    expires 30d;
    add_header Cache-Control "public, immutable";
}

location /uploads/ {
    alias /var/www/myproject/upload_storage/;
    client_max_body_size 20M;
}

location / {
    proxy_pass http://127.0.0.1:8000;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
}

关键安全提示:生产环境禁止将 STATIC_ROOTMEDIA_ROOT 设置为项目代码目录的子目录,防止目录遍历攻击。

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。