django中STATIC_ROOT和STATICFILES_DIRS区别 及MEDIA_ROOT

staticfiles:这是一个静态资源管理的app,django.contrib.staticfiles。老的版本中,静态资源管理一直是一个问题,部分app发布的时候需要带上静态资源,在部署的时候必须将每个app存在的static(这个目录是自己创建的)静态资源复制到项目根目录下同一个static目录(即staticfiles在项目目录下生成的static,与每个app下的static不同)。引入staticfiles之后,执行命令:python manage.py collectstatic就可以方便的将所用到的app中的静态资源复制到同一目录。

 

使用python manage.py collectstatic时项目settings.py中必须有(把所有app目录中的static集中到,项目目录中的static中)

STATIC_ROOT = os.path.join(BASE_DIR, "static")否则会提示错误,如下:

raise ImproperlyConfigured("You're using the staticfiles app "
django.core.exceptions.ImproperlyConfigured: You're using the staticfiles app without having set the STATIC_ROOT setting to a filesystem path.

 

 

此时如果删除app目录下static目录,会有403错误。

要把settings.py中STATIC_ROOT = os.path.join(BASE_DIR, "static")改为

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, "static"),
]  

省事可以不把app目录下static目录删除也不用在变动修改STATIC_ROOT

把app目录下static目录删除也可以,但要在urls.py中加入静态文件处理的代码:

 

from django.contrib.staticfiles.urls import staticfiles_urlpatterns

# This will work if DEBUG is True

urlpatterns += staticfiles_urlpatterns()

还要把settings.py中STATIC_ROOT = os.path.join(BASE_DIR, "static")改为

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, "static"),
]  

 

 

 

 

staticfiles的主要相关配置与分析

  • STATIC_ROOT:运行上边提到的命令:python manage.py collectstatic 之后静态文件将要复制到的目录,这个目录只有在运行collectstatic时候才会用到,不能想当然的以为这个目录和MEDIA_ROOT的作用是相同的,否则在开发环境的时候可能一直无法找到静态文件。

  • STATIC_URL:设置的static file的起始url,这个只是在template里边引用到,这个参数和MEDIA_URL的含义相同。

  • STATICFILES_DIRS:和TEMPLATE_DIRS的含义差不多,就是除了各个app的static目录以外还需要管理的静态文件设置,比如项目的公共文件差不多。

  • 各个app目录下的静态文件static/django会自动找到,这个点和app下的templates目录下差不多。

urls.py中加入静态文件处理的代码:

from django.contrib.staticfiles.urls import staticfiles_urlpatterns

# This will work if DEBUG is True

urlpatterns += staticfiles_urlpatterns()

 

 

STATIC_ROOT及MEDIA_ROOT

1.3之前只有MEDIA_ROOT,不管是网站静态文件(js、css等)还是用户上传的文件都在同一个目录下。1.3开始两个目录分开了

 

这个MEDIA目录是在app根目录下新建的,不是项目根目录

 

补充:

 

 

注意没有和nginx一起部署时,DEBUG =

 

True才能访问django静态资源。

 

首先,我们配置静态文件,要在setting.py里面加入如下几行代码: 
settings.py

# the settings above
# STATIC SETTINGS
STATIC_URL = '/static/'
# BASE_DIR 是项目的绝对地址
STATIC_ROOT = os.path.join(BASE_DIR, 'collect_static')
#以下不是必须的
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'common_static'),
) 

1.STATIC_ROOT

STATIC_ROOT 是在部署静态文件时(pyhtonmanage.pycollectstatic)所有的静态文静聚合的目录,STATIC_ROOT要写成绝对地址,在这里,比如我的项目mysite是/home/mysite/ 
那么STATIC_ROOT 为 /home/mysite/collect_static/ 
当部署项目时,在终端输入:

python manage.py collectstatic
1
django会把所有的static文件都复制到STATIC_ROOT文件夹下

2.STATICFILES_DIRS

STATIC_ROOT 是在部署的时候才发挥作用, 而实际情况下,静态文件的一般安放位置有两种:

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

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

STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'common_static'),
)

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

3.STATIC_URL

那么到此为止,静态文件的机制就可以运作了,但是有一个问题,我能不能通过url直接访问我在项目中的静态文件呢,答案肯定是啦,但是,注意,你是在浏览器是访问,你不可能输入你的静态文件的本地绝对地址吧,比如我的一种图片的本地地址为 /home/mysite/common_static/myapp/photo.png 
那么别人不可能在浏览器上直接输入: 
http://192.168.1.2:8000/home/mysite/common_static/myapp/photo.png 
这样子,浏览器会报错, 没有该页面 
那么django是如何让浏览器也可以访问服务器上的静态文件呢,前面已经说了,直接访问服务器本地的地址是不行的,那就需要一个映射,django利用STATIC_URL来让浏览器可以直接访问静态文件,比如:

STATIC_URL = '/static/'
1
那么可以在浏览器上输入: 
http://192.168.1.2:8000/static/common_static/myapp/photo.png 
那么就相当与访问/home/mysite/common_static/myap/photo.png

所以在浏览器上,利用前缀 STATIC_URL的具体内容,来映射STATIC_ROOT, 
HTTP://192.168.1.2:8000/static 相当于 本地地址的STATIC_ROOT
--------------------- 
作者:吕秀军 
来源:CSDN 
原文:https://blog.csdn.net/jj546630576/article/details/78606531 
版权声明:本文为博主原创文章,转载请附上博文链接!

 

你可能感兴趣的:(web前端,django)