1.加載數(shù)據(jù)庫,數(shù)據(jù)庫的配置不能寫死在seting.py文件中,下面的方式是讀取另外一個文件,配置數(shù)據(jù)庫:
config = ''with open(os.path.join(BASE_DIR, 'config/config.json'), 'rt') as f: config = json.load(f) DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'szrqgl', 'USER': config['db_user'], 'PASSWORD': config['db_pwd'], 'HOST': config['db_host'], 'POST': config['db_port'] }}上面的BASE_DIR一般使用的都是默認值,即:
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
具體操作是創(chuàng)建一個config文件夾,該文件夾和你這個項目包同級,然后在其下面創(chuàng)建一個config.json文件,文件內(nèi)容如下:
{ "db_user": "root", "db_pwd": "123456", "db_host": "127.0.0.1", "db_port": "3306"}在上面的代碼中,ENGINE要說明一下,官方提供了針對不同數(shù)據(jù)庫的的不同操作引擎,以下是經(jīng)常用的幾個:
sqlite數(shù)據(jù)庫:'django.db.backends.sqlite3',
postgreSQL數(shù)據(jù)庫:'django.db.backends.postgresql_psycopg2',
mysql數(shù)據(jù)庫:'django.db.backends.mysql'
oracle數(shù)據(jù)庫:'django.db.backends.oracle'
2.時區(qū)設置和字符集設置,一般用的都是下面三個:
設置保存到數(shù)據(jù)庫時間類型是否為UTC時間,如果不需要請設置為false,默認為true:USE_TZ = True
設置時區(qū):TIME_ZONE = 'Asia/Shanghai'
設置語言:LANGUAGE_CODE = 'zh-hans'
設置字符集:DEFAULT_CHARSET = "utf-8"
3.設置國際化,根據(jù)個人需要進行設置:
國際化:USE_I18N = True
相同內(nèi)容被不同時區(qū)地區(qū)的用戶訪問時,是否以不同格式內(nèi)容展示(例如時間,日期,數(shù)字):USE_L10N = True
4.部署配置:
調(diào)試模式是否開啟:DEBUG = True
訪問web服務的的Ip配置:ALLOWED_HOSTS = ['*']
部署的時候請修改DEBUG和ALLOWED_HOSTS的值,一般將其修改為FALSE和指定ip,例如['127.0.0.1']
5.在setting.py中定義全局變量,該變量的變量名需要全部大寫,否則會引用不到:
CONTEXTBOOL= False
6.app的安裝配置,即INSTALLED_APPS設置,我們新建的項目需要添加到該配置下,每個配置的意義以后說明:
django.contrib.admin —— 管理站點。
django.contrib.auth —— 認證系統(tǒng)。
django.contrib.contenttypes —— 用于內(nèi)容類型的框架。
django.contrib.sessions —— 會話框架,session數(shù)據(jù)可以在數(shù)據(jù)庫中的django_session表中查看。
django.contrib.messages —— 消息框架。
django.contrib.staticfiles —— 管理靜態(tài)文件的框架。
例如:
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'demo1',]
7.django的中間件配置,即MIDDLEWARE設置,所謂中間件就是從用戶請求到用戶請求結束期間所做的操作,即用戶的請求會次從上到下依次執(zhí)行MIDDLEWARE中的配置,然后服務器響應用戶的時候會再次從下至上依次執(zhí)行,和Java的Filter很相像:
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',]
一般的django配置如上圖,如果需要自己添加中間件配置的,也可自己添加,這里不再多說。
8.setting中的加密鹽:
SECRET_KEY = 'i&&2$s&#%7npev^#uix==kis+h$4$ozscefiaw1c%p^+1c(l&6'
該配置是django的安全配置,防止攻擊用的,該值是startProject時用系統(tǒng)的某個算法產(chǎn)生的.
9.靜態(tài)文件目錄配置(重中之重)
# 所有靜態(tài)文件放置目錄,在配置nginx的時候,nginx的靜態(tài)資源要指向這里。
STATIC_ROOT = os.path.join(BASE_DIR, 'static').replace('//', '/')# 別名,這個別名指的是在html引用的名稱
STATIC_URL = '/commonstatic/'
例如,下面的這個static實際上就是commonstatic,其在html里面顯示如下:
{% block styles %} <link rel="stylesheet" href="{% static '/plugins/bootstrapValidator/bootstrapValidator.min.css' %}" rel="external nofollow" >{% endblock %}
# 在django中指定靜態(tài)文件的目錄所在地
STATICFILES_DIRS = ( os.path.join(BASE_DIR, 'commonstatic/').replace('//', '/'),)
一般情況下,上述的靜態(tài)文件配置上面幾乎可通用,絕少數(shù)情況下需要另配。
10.session會話配置(下面的配置會保存在數(shù)據(jù)庫的django_session中):
SESSION_ENGINE = 'django.contrib.sessions.backends.db' # 引擎(默認)SESSION_COOKIE_NAME = "sessionid" # Session的cookie保存在瀏覽器上時的key,即:sessionid=隨機字符串(默認)SESSION_COOKIE_PATH = "/" # Session的cookie保存的路徑(默認)SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名(默認)SESSION_COOKIE_SECURE = False # 是否Https傳輸cookie(默認)SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸(默認)SESSION_COOKIE_AGE = 60 * 30 # Session的cookie失效日期(30min)(默認)SESSION_EXPIRE_AT_BROWSER_CLOSE = True # 是否關閉瀏覽器使得Session過期(默認)SESSION_SAVE_EVERY_REQUEST = True # 是否每次請求都保存Session,默認修改之后才保存(默認)
setting配置文件的內(nèi)容大致如上,具體每個配置的作用會在以后的文章中進行說明!
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點
疑難解答
圖片精選