
1. 環(huán)境
系統(tǒng):Mac OS
IDE:PyCharm
環(huán)境:mac上如何安裝python,如何同時(shí)安裝python2、python3兩個(gè)版本,如何安裝PyCharm,在Python下如何配置django等,這些屬于常見(jiàn)問(wèn)題,網(wǎng)上已經(jīng)有很多的說(shuō)明,在此就不贅述。
2.創(chuàng)建Web項(xiàng)目
1.檢查機(jī)器上的django是否安裝成功
啟動(dòng)終端,在終端中輸入django-admin,如果安裝成功,則會(huì)顯示django-admin下的命令行,如下圖,沒(méi)有顯示則報(bào)錯(cuò),請(qǐng)檢查環(huán)境;

2.用命令創(chuàng)建django項(xiàng)目
在電腦上創(chuàng)建一個(gè)文件夾,用作python專用的工作空間,比如我電腦上python的工作空間為python-works,然后在終端中cd到該文件夾下,輸入以下命令:
django-admin startproject testblog
回車即可創(chuàng)建一個(gè)名稱為testblog的項(xiàng)目。打開(kāi)對(duì)應(yīng)的文件夾,即可看到文件如下:

用PyCharm打開(kāi)該項(xiàng)目,即可看到對(duì)應(yīng)的項(xiàng)目結(jié)構(gòu):

3.各文件的功能
manage.py:
manage.py文件位于整個(gè)項(xiàng)目的最外層,是該項(xiàng)目的項(xiàng)目管理器,它提供了很多的命令用來(lái)管理該項(xiàng)目,在終端中可以查看它提供的所有命令,cd到該項(xiàng)目的目錄下,輸入以下命令:
python3 manage

這些命令用來(lái)管理項(xiàng)目,至于每個(gè)命令的含義,可以查看django的官方文檔,比如runserver使用的比較多,用來(lái)啟動(dòng)項(xiàng)目:
python3 manage.py runserver

此時(shí)testblog項(xiàng)目已經(jīng)啟動(dòng),用瀏覽器訪問(wèn)http://127.0.0.1:8000/,即可看到如下界面:

你肯定會(huì)疑問(wèn),為何你的命令使用的都是python3而不是python?
因?yàn)镸ac自帶了Python2.7,我后來(lái)又安裝了Python3.6,所以我的電腦中存在兩套Python環(huán)境,使用python3命令即是在Python3.6環(huán)境下運(yùn)行該命令。
testblog:
該文件夾是項(xiàng)目自動(dòng)生成的,相當(dāng)于項(xiàng)目容器,其所包含的文件為一個(gè)獨(dú)立的模塊,在一個(gè)項(xiàng)目中可以增加多個(gè)模塊。
wsgi.py:
全稱是 webserver getway interface,即Web服務(wù)器的網(wǎng)關(guān)接口,看到這個(gè)名字是不是瞬間明白了它的作用呢?嘿嘿。是python應(yīng)用與Web服務(wù)器交互的接口,一般不需要做任何修改。
urls.py:
django下所有的頁(yè)面都需要在該urls文件中配置一下,否則在訪問(wèn)的時(shí)候會(huì)找不到該文件。

比如,項(xiàng)目中默認(rèn)添加了admin頁(yè)面,我們就可以訪問(wèn)127.0.0.1:8000/admin。
init.py:
空文件,其作用是聲明testblog為一個(gè)獨(dú)立的模塊
settings.py:
配置文件,各種路徑、國(guó)際化、debug、模版等均在此文件中配置。其內(nèi)容如下代碼,代碼中有詳細(xì)的注釋說(shuō)明:
import os
#項(xiàng)目文件所在的根目錄
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
#自動(dòng)生成的加密密鑰,生產(chǎn)環(huán)境下使用,加密后用戶在以開(kāi)發(fā)者模式看前端界面時(shí)看到的均是加密后的信息
SECRET_KEY = '8*smgq0^^3a@43!f!_nhd_&3q64$c^-1ex#tlwb6k#7x(sil=o'
#Debug模式,上線時(shí)必須要關(guān)閉,為True時(shí),網(wǎng)頁(yè)端的一個(gè)log或者錯(cuò)誤會(huì)在界面上提示,方便開(kāi)發(fā)者查找錯(cuò)誤原因。如果設(shè)置為False,則為生產(chǎn)環(huán)境,此時(shí)下面的ALLOWED_HOSTS必須要配置,否則運(yùn)行時(shí)命令行會(huì)報(bào)錯(cuò),比如配置為127.0.0.1,就可以訪問(wèn)。
DEBUG = True
ALLOWED_HOSTS = []
#系統(tǒng)默認(rèn)安裝好的應(yīng)用,如果后面自己創(chuàng)建了應(yīng)用需要在該數(shù)組中增加應(yīng)用
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
#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',
]
#url配置文件,指向的是項(xiàng)目文件下的urls
ROOT_URLCONF = 'testblog.urls'
#模版的配置文件
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'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 = 'testblog.wsgi.application'
https://docs.djangoproject.com/en/1.11/ref/settings/#databases
#數(shù)據(jù)庫(kù),系統(tǒng)默認(rèn)使用的sqlite3,如果需要使用如mysql的話需要修改此處的信息
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
#密碼認(rèn)證配置項(xiàng)
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',
},
]
#國(guó)際化配置,包括語(yǔ)言、時(shí)區(qū)等
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
#靜態(tài)文件,CSS、JS、圖片所放置的地方
STATIC_URL = '/static/'
3. 小結(jié)
這個(gè)是django創(chuàng)建項(xiàng)目的基本操作,以及django項(xiàng)目的結(jié)構(gòu)和各文件的功能,和其他所有語(yǔ)言一樣,都有一套規(guī)范,項(xiàng)目創(chuàng)建,系統(tǒng)會(huì)自動(dòng)生成一系列文件,每個(gè)文件都有其固定的作用,在進(jìn)一步操作的時(shí)候一定要記得在對(duì)應(yīng)的位置修改對(duì)應(yīng)的配置。