天天看點

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

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前不需要加'/',因為域名的末尾一定會有'/'。其中'^'為嚴格前比對,'$'為嚴格後比對,如果不加$,浏覽器輸入http://localhost:8000/hello/a/b 也是可以通路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 08, 2018 - 05:34:59

Django version 2.1.3, using settings 'djangoDemo.settings'
Starting development server at http://127.0.0.1:8000/

Quit the server with CONTROL-C.
           

項目啟動成功浏覽器輸入

http://localhost:8000/hello/ 我們可以看到如下界面

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

浏覽器輸入 http://localhost:8000/msg/tome/12/

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

下集預告:

通過Django操作Mysql資料的配置和代碼示例

原文釋出時間為: 2018-11-13

本文作者:程式員共成長

本文來自雲栖社群合作夥伴“

程式員共成長

”,了解相關資訊可以關注“

”。