1. 程式人生 > >django setting.py配置詳解

django setting.py配置詳解

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
# __file__ 這個變數可以獲得當前檔案的路徑
# os.path.abspath(__file__)指的是當前檔案的絕對路徑,包括檔名。
# 用 print(os.path.abspath(__file__)) 會得到C:\Users\Administrator\Desktop\Person_web\setting.py
# os.path.dirname(__file__)指的是當前檔案所在目錄。
# 用 print(os.path.dirname(__file__)) 會得到C:\Users\Administrator\Desktop\Person_web
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) #DASE_DIR 表示當前專案檔案目錄的絕對路徑


# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
# 加密鹽,在使用startproject開始生成
SECRET_KEY = 'z(p!9_d0b!)%vk%w+#77)l$!i(0n3r-5u6^ru*xw^+sewc#=3r'

# SECURITY WARNING: don't run with debug turned on in production!
# DEBUG配置為True的時候會暴露出一些出錯資訊或者配置資訊以方便除錯.但是在上線的時候應該將其關掉,防止配置資訊或者敏感出錯資訊洩露.
DEBUG = True

# 是為了限定請求中的host值,以防止黑客構造包來發送請求.只有在列表中的host才能訪問.強烈建議不要使用*萬用字元去配置,另外當DEBUG設定為False的時候必須配置這個配置.否則會丟擲異常.配置模板如下:
ALLOWED_HOSTS = []


# Application definition

# INSTALLED_APPS是一個一元陣列.裡面是應用中要載入的自帶或者自己定製的app包路徑列表.
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'person_app'
]

# web應用中需要載入的一些中介軟體列表.是一個一元陣列.裡面是django自帶的或者定製的中介軟體包路徑,需要注意順序如下:
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指定根級url的配置
ROOT_URLCONF = 'Person_web.urls'

# TEMPLATES 一個列表,包含所有在Django中使用的模板引擎的設定。列表中的每一項都是一個字典,包含某個引擎的選項。
TEMPLATES = [
    {
        # BACKEND 使用的模板引擎, 通過設定BACKEND為一個完整的路徑,可以自定義你想要使用的引擎
        'BACKEND': 'django.template.backends.django.DjangoTemplates',  # django自帶的引擎
        # NAME 該模板引擎的別名。別名在所有配置好的模板引擎中必須是唯一的
        'NAME': 'dj',
        # DIRS 引擎用於查詢模板原始檔的目錄。templates是專案檔案中儲存模板檔案的資料夾。
        # os.path.join():將多個路徑組合後返回
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        # APP_DIRS 引擎是否在已安裝的應用程式(的目錄)內查詢模板原始檔
        'APP_DIRS': True,
        # OPTIONS 傳遞給該模板引擎的其他引數。不同的引擎,可用的引數不一樣。
        '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 = 'Person_web.wsgi.application'


# Database
# https://docs.djangoproject.com/en/1.11/ref/settings/#databases
# 資料庫配置,如果使用Django預設的sqlite3資料庫則不需要修改
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'person',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': 'localhost',
    }
}


# Password validation
# https://docs.djangoproject.com/en/1.11/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/1.11/topics/i18n/

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/

# 靜態檔案目錄
STATIC_URL = '/static/'  # 呼叫時目錄
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]   #具體路徑

Django專案setting.pyp檔案