Django STATIC_URL 的理解

本文详细解析Django框架中静态文件的配置与引用机制,包括STATIC_ROOT、STATICFILES_DIRS、STATIC_URL的设置,以及如何在模板中正确使用静态资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# the settings above
# STATIC SETTINGS
STATIC_URL = '/static/'
# BASE_DIR 是项目的绝对地址
STATIC_ROOT = os.path.join(BASE_DIR, 'collect_static')
#以下不是必须的  各个app共用的文件可以放在这
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'common_static'),
) 
# 这四个都可以定位到文件
{% load staticfiles %}  
    <img src="{% static 'img/1.png' %}" />
    <img src="{% static 'img/3.png' %}" />

    <img src="{{STATIC_URL}}img/1.png" />
    <img src="{{STATIC_URL}}img/3.png" />

一、各个路径文件夹的作用

1.STATIC_ROOT 是在部署的时候才发挥作用,执行 python managy.py collectstatic ,会在工程文件下生成(STATIC_ROOT )文件夹,把各个app下的静态文件收集到这个目录下。当然,需要配置Nginx。

2.STATICFILES_DIRS

静态文件的一般安放位置有两种:

(1).一种就是在每个app里面新建一个static文件夹,将静态文件放到里面,在加载静态文件时,比如要在模板中用到静态文件,django会自动在每个app里面搜索static文件夹(所以,不要把文件夹的名字写错, 否则django就找不到你的文件夹)。

(2).另一种,就是在所有的app文件外面,建立一个公共的文件夹,,也就是我们的STATICFILES_DIRS。因为有些静态文件不是某个app独有的,那么就可以把它放到一个公共文件夹里面,方便管理(注意,建立一个公共的静态文件的文件夹只是一种易于管理的做法,但是不是必须的,app是可以跨app应用静态文件的,因为最后所有的静态文件都会在STATIC_ROOT里面存在) 
那现在的问题是如何让django知道你把一些静态文件放到app以外的公共文件夹中呢,那就需要配置STATICFILES_DIRS了

二、明白Django静态文件的引用:

在static标签中引用文件时有两个查找路径:1、app下的static。2、工程下的commen_static(STATICFILES_DIRS) 。

STATICFILES_DIRS告诉django,首先到STATICFILES_DIRS里面寻找静态文件,其次再到各个app的static文件夹里面找(注意,django查找静态文件是惰性查找,查找到第一个,就停止查找了)

三、STATIC_URL

那么到此为止,静态文件的机制就可以运作了,但是有一个问题,我能不能通过url直接访问我在项目中的静态文件。但是,你在浏览器访问,你不可能输入你的静态文件的本地绝对地址吧,比如我的一种图片的本地地址为

home/blogproject/common_static/img/1.png 
那么别人不可能在浏览器上直接输入: 
http://127.0.0.1:8000/home/blogproject/common_static/img/1.png
这样子,浏览器会报错,,没有该页面 
那么django是如何让浏览器也可以访问服务器上的静态文件呢,前面已经说了,直接访问服务器本地的地址是不行的,那就需要一个映射,django利用STATIC_URL来让浏览器可以直接访问静态文件,比如:

STATIC_URL = '/static/'
那么可以在浏览器上输入: 

http://127.0.0.1:8000/static/img/1.png
http://127.0.0.1:8000/static/img/3.png
那么就相当与访问:

/home/blogproject/common_static/img/1.png

/home/blogproject/mytest/static/img/3.png

也就是说STATIC_URL = '/static/' 可以定位到各个app下的staic/和工程下的commen_static/。

 

所以在浏览器上,利用前缀 STATIC_URL的具体内容,来映射app下的static和STATICFILES_DIRS,
http://127.0.0.1:8000/static/  相当于 本地地址的app/static 和 STATICFILES_DIRS

三、一般我们在模板中使用

<img src="{% static 'img/1.png' %}" />

我们在模板中添加一行 {% load staticfiles %},告诉django模板引擎我们要在模板中使用静态文件。这样,便可以使用static模板标签引入静态目录中的文件。 static 'img/1.png' 告诉django,我们要显示目录名中img/1.png 的文。static标签会在img/1.png前加上STATIC_URL的指定URL,得到/static/img/1.png 。django模板引擎生成如下html

<img src="/static/img/1.png" />

如果使用

    <img src="{{STATIC_URL}}img/3.png" />

需要在setting.py中添加些设置:

1. INSTALLED_APPS 中,加入 'django.contrib.staticfiles'   ,这个一般都有。

2. TEMPLATES 中,context_processors中,加入django.template.context_processors.static

 

参考:

https://blog.youkuaiyun.com/jj546630576/article/details/78606531

https://blog.youkuaiyun.com/wilde_lf/article/details/79402661

<think>好的,用户想了解如何在Django项目的settings.py文件中正确配置STATIC_ROOT。首先,我需要回顾一下Django中静态文件处理的相关知识,特别是STATIC_ROOT的作用以及配置步骤。 根据引用[1],STATIC_ROOT和STATICFILES_DIRS都是用来处理静态文件的配置。STATIC_ROOT指定了收集静态文件的目标目录,而STATICFILES_DIRS告诉Django去哪里寻找静态文件。用户可能混淆了这两者的用途,需要明确区分。 接下来,配置STATIC_ROOT的具体步骤应该包括在settings.py中设置路径,运行collectstatic命令,以及配置URL。引用[1]和[3]中的urls.py配置示例显示,需要通过视图函数serve来处理静态文件的请求,同时引用STATIC_ROOT作为document_root。因此,用户需要在urls.py中添加相应的路由,并确保导入了settings和相关的视图模块。 需要注意,开发环境和生产环境的配置可能不同。在开发阶段,使用Django自带的服务器处理静态文件可能可行,但生产环境通常需要Web服务器(如Nginx)来处理,这时候STATIC_ROOT就非常重要了。用户可能想知道在不同环境下的差异,所以需要提及这一点。 此外,常见的错误可能包括路径设置不正确,导致collectstatic无法正确收集文件,或者urls.py中的路由配置错误。需要提醒用户检查路径是否正确,并确保运行了collectstatic命令。引用[2]提到INSTALLED_APPS需要包含'django.contrib.staticfiles',这也是必须确认的一点,否则静态文件功能无法启用。 最后,生成相关问题时要围绕STATIC_ROOT的配置、相关配置项的区别、常见问题以及生产环境部署等方面,帮助用户进一步理解整个静态文件处理流程。</think>### 如何在 Django settings.py 中配置 STATIC_ROOT #### 1. **理解 STATIC_ROOT 的作用** - **STATIC_ROOT** 是 Django 项目在生产环境中收集所有静态文件(CSS、JS、图片等)的集中存储目录,通常在部署时通过 `python manage.py collectstatic` 命令自动生成[^1][^2]。 - 与 **STATICFILES_DIRS** 的区别:`STATICFILES_DIRS` 是开发阶段指定多个静态文件源目录的配置,而 `STATIC_ROOT` 是最终聚合这些文件的目录。 --- #### 2. **配置步骤** ##### (1) 在 `settings.py` 中设置路径 ```python # settings.py STATIC_URL = '/static/' # 静态文件访问 URL 前缀(必须配置) STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles') # 指定收集静态文件的目标目录 ``` ##### (2) 运行收集命令 在终端执行: ```bash python manage.py collectstatic ``` Django 会将所有应用的 `static/` 目录和 `STATICFILES_DIRS` 中指定的文件复制到 `STATIC_ROOT` 目录。 ##### (3) 生产环境配置(示例) 在 `urls.py` 中添加静态文件路由(仅限开发环境调试,生产环境应由 Web 服务器处理): ```python # urls.py from django.conf import settings from django.urls import re_path from django.views import static urlpatterns += [ re_path(r'^static/(?P<path>.*)$', static.serve, {'document_root': settings.STATIC_ROOT}), ] ``` 引用自静态文件服务配置示例[^3]。 --- #### 3. **注意事项** - **开发环境**:Django 默认会自动处理 `STATICFILES_DIRS` 中的文件,无需配置 `STATIC_ROOT`。 - **生产环境**:必须通过 Web 服务器(如 Nginx)直接托管 `STATIC_ROOT` 目录,而非依赖 Django 视图。 - **路径一致性**:确保 `STATIC_ROOT` 目录不会被版本控制工具(如 Git)跟踪,避免与开发文件冲突。 --- #### 4. **完整配置示例** ```python # settings.py BASE_DIR = Path(__file__).resolve().parent.parent STATIC_URL = '/static/' STATIC_ROOT = BASE_DIR / 'staticfiles' # 使用 Pathlib 语法 STATICFILES_DIRS = [ BASE_DIR / 'myapp/static', # 自定义静态文件目录 ] ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值