- 配置文件settings.py
- 1. BASE_DIR
- 2. DEBUG
- 3. 本地语⾔与时区
- 4. 静态⽂件
- 5. 应⽤配置
"""
Django settings for film_manager project.
Generated by 'django-admin startproject' using Django 2.2.
For more information on this file, see
https://docs.djangoproject.com/en/2.2/topics/settings/
For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.2/ref/settings/
"""
import os
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'sd1ds_!!p7aoq$vs$sqqs6fnmtmdk98&+lpz00my-ihtkb1e26'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'film.apps.FilmConfig'
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = 'film_manager.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
WSGI_APPLICATION = 'film_manager.wsgi.application'
# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
# Password validation
# https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators
AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
},
]
# Internationalization
# https://docs.djangoproject.com/en/2.2/topics/i18n/
LANGUAGE_CODE = 'zh-Hans'
IME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = True
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.2/howto/static-files/
STATIC_URL = '/static/'
1. BASE_DIR
BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
当前⼯程的根⽬录,Django会依此来定位⼯程内的相关⽂件,我们也可以使⽤该参数来构造⽂件路径。
2. DEBUG调试模式,创建⼯程后初始值为True,即默认⼯作在调试模式下。 作⽤:
- 修改代码⽂件,程序⾃动重启
- Django程序出现异常时,向前端显示详细的错误追踪信息,例如:
当我在film/urls.py ⽂件末尾任意输⼊LLO,服务器会⾃动重启,会输出相应的错误提示。
- ⽽⾮调试模式下,仅返回Server Error (500)
注意:部署线上运⾏的Django不要运⾏在调式模式下,记得修改DEBUG=False和ALLOW_HOSTS。
3. 本地语⾔与时区Django⽀持本地化处理,即显示语⾔与时区⽀持本地化。
本地化是将显示的语⾔、时间等使⽤本地的习惯,这⾥的本地化就是进⾏中国化,中国⼤陆地区使⽤简体中⽂,时区使⽤亚洲/上海时区,注意这⾥不使⽤北京时区表示。
初始化的⼯程默认语⾔和时区为英语和UTC标准时区
LANGUAGE_CODE = 'en-us' # 语⾔
TIME_ZONE = 'UTC' # 时区# 时区
将语⾔和时区修改为中国⼤陆信息
LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'
4. 静态⽂件
项⽬中的css、image、js都是静态⽂件。⼀般会将静态⽂件放到⼀个单独的⽬录中,以⽅便管理。在html⻚⾯中调⽤时,也需要指定静态⽂件的路径,Django中提供了⼀种解析的⽅式配置静态⽂件路径。静态⽂件可以放在项⽬根⽬录下,也可以放在应⽤的⽬录下,由于有些静态⽂件在项⽬中是通⽤的,所以推荐放在项⽬的根⽬录下,⽅便管理。
为了提供静态⽂件,需要配置两个参数:
STATICFILES_DIRS
存放查找静态⽂件的⽬录STATIC_URL
访问静态⽂件的URL前缀
示例 1) 在项⽬根⽬录下创建static⽬录来保存静态⽂件。 2) 在film_manager/settings.py中修改静态⽂件的两个参数为
STATIC_URL = '/static/'
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static'),
]
3)此时在static
添加的任何静态⽂件都可以使⽤⽹址/static/
⽂件在static
中的路径来访问了。
例如,我们向static
⽬录中添加⼀个login.html
⽂件,在浏览器中就可以使⽤127.0.0.1J8000/static/login.html
来访问。
在每个应⽤⽬录中都包含了apps.py⽂件,⽤于保存该应⽤的相关信息。
在创建应⽤时,Django会向apps.py⽂件中写⼊⼀个该应⽤的配置类,如
from django.apps import AppConfig
class FilmConfig(AppConfig):
name = 'film'
我们将此类添加到⼯程settings.py
中的INSTALLED_APPS
列表中,表明注册安装具备此配置属性的应⽤。
AppConfig.name
属性表示这个配置类是加载到哪个应⽤的,每个配置类必须包含此属性,默认⾃动⽣成。
AppConfig.verbose_name
属性⽤于设置该应⽤的直观可读的名字,此名字在Django提供的Admin管理站点中会显示,如
from django.apps import AppConfig
class UsersConfig(AppConfig):
name = 'film'
verbose_name = '影⽚管理