Django通过django.contrib.staticfiles
来管理静态文件。
django.contrib.staticfiles
已经添加到INSTALLED_APPS
STATIC_URL
,例如STATIC_URL = '/static/'
/static/my_app/example.jpg
。二是使用static
模板标签:
{% load static %} ![]({% static )
static
目录下。在开发环境下,当通过runserver
启动并且debug=True
的时候,服务器会自动转发静态文件,但是这样做效率并不高,也不安全,不适合生产环境。
如果你不想将静态文件放在应用的目录下,而是统一放在某个目录下,可以通过STATICFILES_DIRS
进行配置:
STATICFILES_DIRS = [
os.path.join(BASE_DIR, "static"),
'/var/www/static/',
]
django.contrib.staticfiles
提供了一个很好的命令用来收集所有的静态文件,并统一放在一个目录下面。
STATIC_ROOT
,用来保存最终的静态文件, 例如:
STATIC_ROOT = "/var/www/example.com/static/"
collectstatic
命令,执行下面的命令会将所有的静态文件都拷贝到STATIC_ROOT
目录下。
$ python manage.py collectstatic
一般的,生产环境不会通过django来转发静态文件,而是通过其他服务器进行转发,比如nginx,apache等。
STATIC_ROOT
用来保存收集到的静态文件,服务器最终也将从该路径中获取文件进行转发。
STATIC_URL
用来引用静态文件,也就是渲染之后HTML中静态文件的前缀。