很詳細的Django入門詳解

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

開始前的準備工做

搭建虛擬環境

隨着咱們項目的積累,有時候不一樣項目須要用不到不一樣版本的包,可能會產生衝突,這時候咱們須要一個虛擬環境將每一個項目須要的包進行獨立,這樣就能有效避免衝突。css

安裝MySql

Django支持不少中類型的數據庫,默認配置的sqlite3,在學習過程當中咱們用到了Mysql前端

安裝Python三、pip、PyCharm

Django2.0和之後的版本再也不支持Python2.X,因此咱們須要安裝Python3.6版本的解釋器。
pip是一個通用的Python包管理工具,能夠對包進行查找、安裝、卸載
PyCharm是一種Python IDE,牆裂推薦。python

以上準備工做,小夥伴們能夠自行網上查找相關教程。mysql

初探Django

經過準備工做咱們的系統中已經安裝pip,經過使用pip安裝最新版的Django。nginx

pip3 install django

安裝完成以後咱們能夠經過 python3 -m django --version 查看當前Django版本程序員

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

建立一個Django項目

一、咱們能夠經過終端輸入命令行建立一個項目

這裏個人項目名爲 djangoDemoweb

django-admin.py startproject djangoDemo
二、也能夠經過pycharm的create new project進行建立

在這裏插入圖片描述在這裏插入圖片描述sql

查看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
目錄說明:

一、djangoDemo/djangoDemo: 項目最初的Python包

二、djangoDemo/init.py: 一個空文件,聲明所在目錄的包爲一個Python包

三、djangoDemo/settings.py: 管理項目的配置信息

四、djangoDemo/urls.py: 聲明請求url的映射關係

五、djangoDemo/wsgi.py: python程序和web服務器的通訊協議

六、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_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\w+) 表示name字段的值範圍爲非數字的字符即:a-z A-Z 漢字、(?P\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/ 咱們能夠看到以下界面

在這裏插入圖片描述在這裏插入圖片描述
瀏覽器輸入 http://localhost:8000/msg/tome/12/
在這裏插入圖片描述在這裏插入圖片描述

 

關注公衆號「程序員共成長」(id: finishbug)。給新加入的小夥伴準備了豐厚的見面禮,包括但不限於:Python、Java、Linux、大數據、人工智能、前端等21個技術方向,後臺回覆"禮包"便可領取。

相關文章
相關標籤/搜索