溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Django框架的中的setting.py文件說明詳解

發(fā)布時間:2020-10-25 07:42:02 來源:腳本之家 閱讀:119 作者:豆芽胡 欄目:開發(fā)技術(shù)

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一般使用的都是默認(rèn)值,即:

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

具體操作是創(chuàng)建一個config文件夾,該文件夾和你這個項(xiàng)目包同級,然后在其下面創(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è)置和字符集設(shè)置,一般用的都是下面三個:

設(shè)置保存到數(shù)據(jù)庫時間類型是否為UTC時間,如果不需要請?jiān)O(shè)置為false,默認(rèn)為true:USE_TZ = True

設(shè)置時區(qū):TIME_ZONE = 'Asia/Shanghai'

設(shè)置語言:LANGUAGE_CODE = 'zh-hans'

設(shè)置字符集:DEFAULT_CHARSET = "utf-8"

3.設(shè)置國際化,根據(jù)個人需要進(jìn)行設(shè)置:

國際化:USE_I18N = True

相同內(nèi)容被不同時區(qū)地區(qū)的用戶訪問時,是否以不同格式內(nèi)容展示(例如時間,日期,數(shù)字):USE_L10N = True

4.部署配置:

調(diào)試模式是否開啟:DEBUG = True

訪問web服務(wù)的的Ip配置:ALLOWED_HOSTS = ['*']

部署的時候請修改DEBUG和ALLOWED_HOSTS的值,一般將其修改為FALSE和指定ip,例如['127.0.0.1']

5.在setting.py中定義全局變量,該變量的變量名需要全部大寫,否則會引用不到:

CONTEXTBOOL= False

6.app的安裝配置,即INSTALLED_APPS設(shè)置,我們新建的項(xiàng)目需要添加到該配置下,每個配置的意義以后說明:

django.contrib.admin —— 管理站點(diǎn)。

django.contrib.auth —— 認(rèn)證系統(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設(shè)置,所謂中間件就是從用戶請求到用戶請求結(jié)束期間所做的操作,即用戶的請求會次從上到下依次執(zhí)行MIDDLEWARE中的配置,然后服務(wù)器響應(yīng)用戶的時候會再次從下至上依次執(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實(shí)際上就是commonstatic,其在html里面顯示如下:

{% block styles %}
  <link rel="stylesheet" href="{% static '/plugins/bootstrapValidator/bootstrapValidator.min.css' %}" rel="external nofollow" >
{% endblock %}

Django框架的中的setting.py文件說明詳解

# 在django中指定靜態(tài)文件的目錄所在地

STATICFILES_DIRS = (
  os.path.join(BASE_DIR, 'commonstatic/').replace('\\', '/'),
)

Django框架的中的setting.py文件說明詳解

一般情況下,上述的靜態(tài)文件配置上面幾乎可通用,絕少數(shù)情況下需要另配。

10.session會話配置(下面的配置會保存在數(shù)據(jù)庫的django_session中):

SESSION_ENGINE = 'django.contrib.sessions.backends.db' # 引擎(默認(rèn))
SESSION_COOKIE_NAME = "sessionid" # Session的cookie保存在瀏覽器上時的key,即:sessionid=隨機(jī)字符串(默認(rèn))
SESSION_COOKIE_PATH = "/" # Session的cookie保存的路徑(默認(rèn))
SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名(默認(rèn))
SESSION_COOKIE_SECURE = False # 是否Https傳輸cookie(默認(rèn))
SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http傳輸(默認(rèn))
SESSION_COOKIE_AGE = 60 * 30 # Session的cookie失效日期(30min)(默認(rèn))
SESSION_EXPIRE_AT_BROWSER_CLOSE = True # 是否關(guān)閉瀏覽器使得Session過期(默認(rèn))
SESSION_SAVE_EVERY_REQUEST = True # 是否每次請求都保存Session,默認(rèn)修改之后才保存(默認(rèn))

setting配置文件的內(nèi)容大致如上,具體每個配置的作用會在以后的文章中進(jìn)行說明!

 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI