[Django青銅修煉手冊] 初識Django

程式設計師共同成長發表於2018-11-15

Django 是用Python開發的一個免費開源的Web框架,可以用於快速搭建高效能,優雅的網站!採用了MVC的框架模式,即模型M,檢視V和控制器C,也可以稱為MVT模式,模型M,檢視V,模板T。在學習Django的過程中將學到的知識進行總結分享出來,溫故而知新,如果能幫助到想學Django但不知道如何開始的同學是再好不過了。

開始前的準備工作  

1、搭建虛擬環境

    隨著我們專案的積累,有時候不同專案需要用不到不同版本的包,可能會產生衝突,這時候我們需要一個虛擬環境將每個專案需要的包進行獨立,這樣就能有效避免衝突。

2、安裝MySql

    Django支援很多中型別的資料庫,預設配置的sqlite3,在學習過程中我們用到了Mysql

3、安裝Python3、pip、PyCharm 

    Django2.0和以後的版本不再支援Python2.X,所以我們需要安裝Python3.6版本的直譯器。

    pip是一個通用的Python包管理工具,可以對包進行查詢、安裝、解除安裝
    PyCharm是一種Python IDE,牆裂推薦。

以上準備工作,小夥伴們可以自行網上查詢相關教程。

初探Django 

透過準備工作我們的系統中已經安裝pip,透過使用pip安裝最新版的Django。

pip3 install django

安裝完成之後我們可以透過  python3 -m django --version 檢視當前Django版本

(django_venv) xxxAir:djangoDemo xxx$ python3 -m django --version
2.1.3

建立一個Django專案

1、我們可以透過終端輸入命令列建立一個專案

這裡我的專案名為 djangoDemo

django-admin.py startproject djangoDemo

2、也可以透過pycharm的create new  project進行建立

[Django青銅修煉手冊] 初識Django

檢視Django專案的目錄結構

切換終端到專案所屬目錄,使用tree命令可以檢視專案結構

mac安裝tree:        brew install 

ubuntu安裝tree:    sudo apt-get install tree

centos安裝tree:     sudo yum -y install tree

執行 「tree + 專案名」

tree djangoDemo

djangoDemo/
├── djangoDemo
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── manage.py

目錄說明:

1、djangoDemo/djangoDemo: 專案最初的Python包

2、djangoDemo/__init__.py: 一個空檔案,宣告所在目錄的包為一個Python包

3、djangoDemo/settings.py: 管理專案的配置資訊

4、djangoDemo/urls.py:  宣告請求url的對映關係

5、djangoDemo/wsgi.py: python程式和web伺服器的通訊協議

6、manage.py: 一個命令列工具,用來和Django專案進行互動,如前面建立專案就用到了該檔案。

專案配置檔案--setting.py

setting.py 檔案用來配置整個專案,裡面的欄位非常多,所以在開始之前有必要先都瞭解一下預設的配置有哪些

import os

# 專案的相對路徑,啟動服務的時候會執行這個檔案所在路徑的manage.py
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

# 安全金鑰
SECRET_KEY = 'l&!v_npes(!j82+x(44vt+h&#ag7io2x&shnf*9^8fv0d63!0r'

# 是否開啟Debug
DEBUG = True

# 允許訪問的主機ip,可以用萬用字元*
ALLOWED_HOSTS = []

# Application definition

# 用來註冊App 前6個是django自帶的應用
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

# 中介軟體 ,需要載入的中介軟體。比如在請求前和響應後根據規則去執行某些程式碼的方法
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列表檔案 父級URL配置
ROOT_URLCONF = 'djangoDemo.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的配置檔案路徑
WSGI_APPLICATION = 'djangoDemo.wsgi.application'

# 資料庫配置 預設的資料庫為sqlite
DATABASES = {
    'default': {
        'ENGINE''django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

# 相關密碼驗證
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',
    },
]

# 語言設定 預設英語, 中文是zh-hans
LANGUAGE_CODE = 'en-us'

# 時區設定,中國的是:Asia/Shanghai
TIME_ZONE = 'UTC'

# i18n字符集是否支援
USE_I18N = True

USE_L10N = True

# 是否使用timezone
# 保證儲存到資料庫中的是 UTC 時間;
# 在函式之間傳遞時間引數時,確保時間已經轉換成 UTC 時間;
USE_TZ = True

# 靜態檔案路徑
STATIC_URL = '/static/'

App

    接下來要引入一個APP的概念,舉個例子我們需要開發一個電商網站,那麼產品列表、購物車、下單等等這都是不同的業務線,我們可以把每條業務線都看做一個App。

建立App

建立一個名為app_demo的應用,  在終端專案目錄下執行

 python3 manage.py startapp app_demo

再次tree 檢視目錄結構 

├── app_demo
│   ├── __init__.py
│   ├── admin.py
│   ├── apps.py
│   ├── migrations
│   │   └── __init__.py
│   ├── models.py
│   ├── tests.py
│   └── views.py
├── djangoDemo
│   ├── __init__.py
│   ├── __pycache__
│   │   ├── __init__.cpython-36.pyc
│   │   └── settings.cpython-36.pyc
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── manage.py

app_demo目錄結構

    admin:對應應用後臺管理配置檔案

    apps:對應應用的配置檔案

    models:資料模組,用於設計資料庫等

    tests:編寫測試指令碼

    views:檢視層,直接和瀏覽器進行互動

    每次新建一個App我們需要將其在settings.py檔案中的INSTALLED_APPS裡進行註冊,這樣程式才能夠找到這個服務

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app_demo'# 註冊新建立的應用app
]

HelloWorld

    helloworld任何一門語言的開始,所以,我們入門的帶個程式也從這裡開始。前面說過Django框架式MVT結構的,這裡由於沒有用到資料和模板所以只需要在V(檢視層)進行coding。

開啟app_demo目錄下的view.py, 開始coding

from django.http import HttpResponse
"""
 django.http模組中定義了HttpResponse 物件的API
 作用:不需要呼叫模板直接返回資料
 HttpResponse屬性:
    content: 返回內容,字串型別
    charset: 響應的編碼字符集
    status_code: HTTP響應的狀態碼
"""


"""
hello 為一個檢視函式,每個檢視函式必須第一個引數為request。哪怕用不到request。
request是django.http.HttpRequest的一個例項
"""

def hello(request):
    return HttpResponse('Hello World')

    檢視層寫完,最終透過HttpResponse將'Hello World'進行響應。

    前面提到過urls是用來宣告請求url的對映關係。也就是程式透過urls裡的配置來找到我們寫的這個view。

# 匯入url模組
from django.conf.urls import url

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r'^hello/$', views.hello)
]

上面的程式碼就是在djangoDemo下的view檔案中加入

from django.conf.urls import url

url(r'^hello/$', views.hello)

    在urlpatterns中加入url('hello/', views.hello),第一個元素是匹配的字串,第二個元素為相對應的檢視模組。

    也就是告訴django所有url/hello/ 的請求都是指向了views.hello 這個檢視。hello前不需要加'/',因為域名的末尾一定會有'/'。其中'^'為嚴格前匹配,'$'為嚴格後匹配,如果不加$,瀏覽器輸入 也是可以訪問view.hello檢視

再來個栗子

    app_demo的views模組中繼續新增(和前面寫的hello檢視同檔案)

def msg(request, name, age):
    return HttpResponse('My name is ' + name + ',i am ' + age + ' years old')

    setting中app_demo這個app前面已經註冊過,所以不需要再次註冊,在urls配置他們的關係對映

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r'^hello/$', views.hello),
    url(r'^msg/(?P<name>\w+)/(?P<age>\d+)/$', views.msg)
]

這個就是透過正則去匹配我們的url,(?P<name>\w+) 表示name欄位的值範圍為非數字的字元即:a-z A-Z 漢字、(?P<age>\d+) 表示age欄位只能是數字

啟動專案

透過執行如下命令來啟動專案

python3 manage.py runserver

預設埠號為:8000,當8000埠被佔用時,我們也可以手動去更換埠,如更換成8080

python3 manage.py runserver 8080

控制檯輸入一下內容則表示啟動成功:

Performing system checks...

System check identified no issues (0 silenced).

You have 15 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
Run 'python manage.py migrate' to apply them.

November 082018 - 05:34:59
Django version 2.1.3using settings 'djangoDemo.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

專案啟動成功瀏覽器輸入

我們可以看到如下介面

[Django青銅修煉手冊] 初識Django

瀏覽器輸入 

[Django青銅修煉手冊] 初識Django


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31562041/viewspace-2220191/,如需轉載,請註明出處,否則將追究法律責任。

相關文章