一、Django簡(jiǎn)介
Django是用Python開發(fā)的一個(gè)免費(fèi)開源的Web框架,可以用于快速搭建高性能,優(yōu)雅的網(wǎng)站!
初次發(fā)布于2005年7月,并于2008年發(fā)布了第一個(gè)正式版本1.0。
官方文檔: https://www.djangoproject.com/
二、Django特點(diǎn)
- 強(qiáng)大的數(shù)據(jù)庫(kù)功能: 擁有強(qiáng)大的數(shù)據(jù)庫(kù)操作接口(QuerySet API),如需要也能執(zhí)行原生SQL。
- 自帶強(qiáng)大的后臺(tái): 幾行簡(jiǎn)單的代碼就讓你的網(wǎng)站擁有一個(gè)強(qiáng)大的后臺(tái),輕松管理內(nèi)容!
- 優(yōu)雅的網(wǎng)址: 用正則匹配網(wǎng)址,傳遞到對(duì)應(yīng)函數(shù),隨意定義,如你所想!
- 模板系統(tǒng): 強(qiáng)大,易擴(kuò)展的模板系統(tǒng),設(shè)計(jì)簡(jiǎn)易,代碼,樣式分開設(shè)計(jì),更容易管理。
(注:前后端分離時(shí),也可以用Django開發(fā)API,完全不用模板系統(tǒng)。) - 緩存系統(tǒng),與Memcached, Redis等緩存系統(tǒng)聯(lián)用,更出色的表現(xiàn),更快的加載速度。
- 國(guó)際化,完全支持多語(yǔ)言應(yīng)用,允許你定義翻譯的字符,輕松翻譯成不同國(guó)家的語(yǔ)言。
三、MVC模式
MVC是一種軟件設(shè)計(jì)典范,用一種業(yè)務(wù)邏輯、數(shù)據(jù)、界面顯示分離的方法組織代碼,將業(yè)務(wù)邏輯聚集到一個(gè)部件中,在改進(jìn)和個(gè)性化定制界面及用戶交互的同時(shí),不需要重新編寫業(yè)務(wù)邏輯。MVC被獨(dú)特的發(fā)展起來用于映射傳統(tǒng)的輸入、處理和輸出功能在一個(gè)邏輯的圖形化用戶界面的結(jié)構(gòu)中。
- Model(模型)
應(yīng)用程序中用于處理應(yīng)用程序數(shù)據(jù)邏輯部分;
通常模型對(duì)象負(fù)責(zé)在數(shù)據(jù)庫(kù)中存取數(shù)據(jù);
- View(視圖)
應(yīng)用程序中處理數(shù)據(jù)顯示部分;
通常視圖是依據(jù)模型數(shù)據(jù)創(chuàng)建的;
- Controller(控制器)
應(yīng)用程序中處理用戶交互部分;
通??刂破髫?fù)責(zé)從視圖中讀取數(shù)據(jù),控制用戶輸入,并向模型發(fā)送數(shù)據(jù);
優(yōu)點(diǎn): 降低各個(gè)功能模塊之間的耦合性,方便變更,更容易重構(gòu)代碼,最大程度上實(shí)現(xiàn)代碼的重用。
四、MTV模式
本質(zhì)上MTV與MVC模式?jīng)]有什么區(qū)別,也是各組件之間為了保持松耦合關(guān)系,只是定義上有些不同。
- Model(模型)
負(fù)責(zé)業(yè)務(wù)對(duì)象與數(shù)據(jù)庫(kù)對(duì)象(ORM)
- Template(模板)
負(fù)責(zé)如何把頁(yè)面展示給用戶
- View(視圖)
負(fù)責(zé)業(yè)務(wù)邏輯,并在適當(dāng)?shù)臅r(shí)候調(diào)用Model和Template
Django還有一個(gè)url分發(fā)器,它的作用是將一個(gè)個(gè)URL的頁(yè)面請(qǐng)求分發(fā)給不同的view處理,view再調(diào)用相應(yīng)的Model和Template。
五、Django環(huán)境搭建
-
Django版本選擇
Django 1.5.x 支持 Python 2.6.5 Python 2.7, Python 3.2 和 3.3. Django 1.6.x 支持 Python 2.6.X, 2.7.X, 3.2.X 和 3.3.X Django 1.7.x 支持 Python 2.7, 3.2, 3.3, 和 3.4 (注意:Python 2.6 不支持了) Django 1.8.x 支持 Python 2.7, 3.2, 3.3, 3.4 和 3.5. (長(zhǎng)期支持版本 LTS) Django 1.9.x 支持 Python 2.7, 3.4 和 3.5. 不支持 3.3 了 Django 1.10.x 支持 Python 2.7, 3.4 和 3.5 Django 1.11.x 支持 Python 2.7, 3.4, 3.5 和 3.6(長(zhǎng)期支持版本 LTS) Django 2.0.x 支持 Python 3.4, 3.5 和 3.6 (注意,不再支持 Python 2)
-
pip安裝(如果有直接跳過)
- 下載get-pip.py文件(Linux, Mac OSX, Windows都可用) https://bootstrap.pypa.io/get-pip.py - 安裝(在終端中運(yùn)行) $ python get-pip.py 備注: 當(dāng)Python2.x和Python3.x共存的時(shí)候要區(qū)分是哪個(gè)版本需要安裝;
pip更新(Linux或MacOS): pip install -U pip
pip更新(Windows): python -m pip install -U pip
-
安裝Django
- 安裝 $ pip install Django==1.11.4 - 驗(yàn)證是否成功() 進(jìn)入到python環(huán)境(終端中輸入python) >>> import django >>> django.get_version() '1.11.4'
操作時(shí),請(qǐng)切換到python3的虛擬環(huán)境中!
六、Django項(xiàng)目創(chuàng)建
- 新建Django項(xiàng)目:
$ django-admin startproject projectName
- 目錄層級(jí)說明:
manage.py 一個(gè)命令行工具,可以使我們多種方式對(duì)Django項(xiàng)目進(jìn)行交互
projectName/__init__.py 一個(gè)空文件,告訴python這個(gè)目錄被看做一個(gè)python包(有這個(gè)能稱之為包)
projectName/settings.py 項(xiàng)目的配置文件
projectName/urls.py 項(xiàng)目URL聲明(路由器)
projectName/wsgi.py 項(xiàng)目與WSGI兼容的Web服務(wù)器入口(網(wǎng)關(guān)接口,通常用在現(xiàn)線上環(huán)境部署)
- 項(xiàng)目的運(yùn)行:
$ python manage.py runserver
$ python manage.py runserver 0.0.0.0:8000
$ python manage.py runserver 0:8000 # 0.0.0.0簡(jiǎn)寫方式
- settings.py項(xiàng)目配置文件
BASE_DIR 項(xiàng)目根目錄
SECRET_KEY 秘鑰
DEBUG 調(diào)試的開啟
ALLOWED_HOSTS 允許訪問的主機(jī)
INSTALLED_APPS 安裝的應(yīng)用
MIDDLEWARE 中間件
ROOT_URLCONF 站點(diǎn)url配置
TEMPLATES 模板
WSGI_APPLICATION wsig應(yīng)用
DATABASES 數(shù)據(jù)庫(kù)
AUTH_PASSWORD_VALIDATORS 密碼驗(yàn)證規(guī)則
LANGUAGE_CODE 語(yǔ)言(中文: zh-hans)
TIME_ZONE 時(shí)區(qū) (中國(guó)時(shí)區(qū): Asia/Shanghai)
- 站點(diǎn)管理的漢化版(在settings.py中替換以下內(nèi)容即可)
LANGUAGE_CODE = 'en-us' 替換 LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'UTC' 替換 TIME_ZONE = 'Asia/Shanghai'
備注: Linux或Mac下,直接在終端中操作;而在Windows中在cmd中操作(開始 -> 搜索cmd)
Linux中輸入tree可以看到具體的目錄結(jié)構(gòu)(樹狀)
七、創(chuàng)建應(yīng)用
要先進(jìn)入項(xiàng)目目錄下,cd projectName
然后執(zhí)行下面的命令:
$ python3 manage.py startapp appName
項(xiàng)目文件說明:
admin.py 站點(diǎn)配置
models.py 模型
views.py 視圖
其實(shí)一個(gè)項(xiàng)目中可以創(chuàng)建多個(gè)應(yīng)用;
sqlite是輕量級(jí)小型數(shù)據(jù)庫(kù)(嵌入級(jí)數(shù)據(jù)庫(kù)),在Django中默認(rèn)使用的就是sqlite【一般在手機(jī)APP中都會(huì)使用到這個(gè)sqlite】
八、激活應(yīng)用
在settings.py
文件中,將appName
應(yīng)用加入到INSTALL_APPS
選項(xiàng)中.
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'appName' # 添加自己的應(yīng)用
]
請(qǐng)求流程: 用戶請(qǐng)求 -> urls -> views -> templates -> 用戶響應(yīng) 【從后往前寫】
九、視圖
- 方式一
def hello(request):
return HttpResponse('hello')
- 方式二
def hello(request):
# hello.html模板
return render(request, 'hello.html')
十、啟動(dòng)服務(wù)器
語(yǔ)法:
python manage.py runserver ip:port
例如:
python manage.py runserver
備注:
IP可以不寫,代表即是本機(jī)IP
端口號(hào)默認(rèn)是8000
啟動(dòng)成功后,在瀏覽器可以看到”It worked!”
說明:
這是一個(gè)純python寫的輕量級(jí)web服務(wù)器,僅僅在開發(fā)測(cè)試階段中使用