Django: 配置和静态文件

时间:2022-03-30 06:57:06

运行django-admin.py startproject [project-name] 命令会生成一系列文件,在django 1.6版本以后的settings.py文件中有以下语句:

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
import os
BASE_DIR = os.path.dirname(os.path.dirname(__file__))

这里用到了python中一个神奇的变量 __file__这个变量可以获取到当前文件(包含这个代码的文件)路径。os.path.dirname(__file__)得到文件所在目录,再来一个os.path.dirname()就是目的上一级BASE_DIR即为项目所在目录。我们在后面的与目录有关的变量都用它,这样使得移植性更强。

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
TEMPLATE_DEBUG = True

DEBUG=True时,如果出现bug便于我们看见问题所在,但是部署时最好不要让用户看见bug的详情,可能一些不怀好心的人攻击网站,造成不必要的麻烦。

ALLOWED_HOSTS = ['*.besttome.com','www.wulaoer.org']

ALLOWED_HOSTS允许你设置那些域名可以访问,即使在Apache中绑定了,这里不允许的话,也是不能访问的。

当DEBUG=False时,这个为必填项,如果不想输入,可以用ALLOW_HOSTS = ['*']来允许所有的。

STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR,'static')

static是静态文件所有目录,比如jquery.js,bootstarp.min.css等文件。

一般来说我们只要把静态文件放在APP中的static目录下,部署时用 python manage.py collectstatic 就可以把静态文件收集到STATIC_ROOT目录,但是有时我们有一些共用的静态文件,这时候可以设置STATICFILES_DIRS另外弄一个文件夹,如下:

STATICFILES_DIRS = (
os.path.join(BASE_DIR, "common_static"),
'/var/www/static/',
)

这样我们就可以把静态文件放在common_static和/var/www/static/中了,Django也能找到它们。

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR,'media')

media文件夹用来存放用户上传的文件,与权限有关,详情见 Django静态文件 和Django部署

有时候一些模版不是属于app的,比如baidutongji.html,share.html等,

Django 1.5 - Django 1.7

TEMPLATE_DIRS = (
os.path.join(BASE_DIR, 'templates').replace('\\', '/'),
os.path.join(BASE_DIR, 'templates2').replace('\\', '/'),
# ...
)

Django 1.8及以上版本

TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [
os.path.join(BASE_DIR,'templates').replace('\\', '/'),
os.path.join(BASE_DIR,'templates2').replace('\\', '/'),
],
'APP_DIRS': True,
]

这样就可以把模版文件放在templates和templates2文件夹中了。