成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Django有什么作用-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了“Django有什么作用”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Django有什么作用”這篇文章吧。

成都網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、成都網(wǎng)站建設(shè)、微信開發(fā)、小程序設(shè)計、集團(tuán)成都定制網(wǎng)站等服務(wù)項目。核心團(tuán)隊均擁有互聯(lián)網(wǎng)行業(yè)多年經(jīng)驗,服務(wù)眾多知名企業(yè)客戶;涵蓋的客戶類型包括:PE包裝袋等眾多領(lǐng)域,積累了大量豐富的經(jīng)驗,同時也獲得了客戶的一致稱譽(yù)!

Django 是用Python開發(fā)的一個免費開源的Web框架,可以用于快速搭建高性能,優(yōu)雅的網(wǎng)站!采用了MVC的框架模式,即模型M,視圖V和控制器C,也可以稱為MVT模式,模型M,視圖V,模板T。在學(xué)習(xí)Django的過程中將學(xué)到的知識進(jìn)行總結(jié)分享出來,溫故而知新,如果能幫助到想學(xué)Django但不知道如何開始的同學(xué)是再好不過了。

開始前的準(zhǔn)備工作

1、搭建虛擬環(huán)境

    隨著我們項目的積累,有時候不同項目需要用不到不同版本的包,可能會產(chǎn)生沖突,這時候我們需要一個虛擬環(huán)境將每個項目需要的包進(jìn)行獨立,這樣就能有效避免沖突。

2、安裝MySql

    Django支持很多中類型的數(shù)據(jù)庫,默認(rèn)配置的sqlite3,在學(xué)習(xí)過程中我們用到了Mysql

3、安裝Python3、pip、PyCharm 

    Django2.0和以后的版本不再支持Python2.X,所以我們需要安裝Python3.6版本的解釋器。

    pip是一個通用的Python包管理工具,可以對包進(jìn)行查找、安裝、卸載
    PyCharm是一種Python IDE,墻裂推薦。

以上準(zhǔn)備工作,小伙伴們可以自行網(wǎng)上查找相關(guān)教程。

初探Django

通過準(zhǔn)備工作我們的系統(tǒng)中已經(jīng)安裝pip,通過使用pip安裝最新版的Django。

pip3 install django

安裝完成之后我們可以通過  python3 -m django --version 查看當(dāng)前Django版本

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

創(chuàng)建一個Django項目

1、我們可以通過終端輸入命令行創(chuàng)建一個項目

這里我的項目名為 djangoDemo

django-admin.py startproject djangoDemo

2、也可以通過pycharm的create new  project進(jìn)行創(chuàng)建

Django有什么作用

查看Django項目的目錄結(jié)構(gòu)

切換終端到項目所屬目錄,使用tree命令可以查看項目結(jié)構(gòu)

mac安裝tree:        brew install 

ubuntu安裝tree:    sudo apt-get install tree

centos安裝tree:     sudo yum -y install tree

執(zhí)行 「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的映射關(guān)系

5、djangoDemo/wsgi.py: python程序和web服務(wù)器的通信協(xié)議

6、manage.py: 一個命令行工具,用來和Django項目進(jìn)行交互,如前面創(chuàng)建項目就用到了該文件。

項目配置文件--setting.py

setting.py 文件用來配置整個項目,里面的字段非常多,所以在開始之前有必要先都了解一下默認(rèn)的配置有哪些

import os

# 項目的相對路徑,啟動服務(wù)的時候會運行這個文件所在路徑的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

# 允許訪問的主機(jī)ip,可以用通配符*
ALLOWED_HOSTS = []

# Application definition

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

# 中間件 ,需要加載的中間件。比如在請求前和響應(yīng)后根據(jù)規(guī)則去執(zhí)行某些代碼的方法
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'

# 加載網(wǎng)頁模板路徑
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'

# 數(shù)據(jù)庫配置 默認(rèn)的數(shù)據(jù)庫為sqlite
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

# 相關(guān)密碼驗證
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',
    },
]

# 語言設(shè)置 默認(rèn)英語, 中文是zh-hans
LANGUAGE_CODE = 'en-us'

# 時區(qū)設(shè)置,中國的是:Asia/Shanghai
TIME_ZONE = 'UTC'

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

USE_L10N = True

# 是否使用timezone
# 保證存儲到數(shù)據(jù)庫中的是 UTC 時間;
# 在函數(shù)之間傳遞時間參數(shù)時,確保時間已經(jīng)轉(zhuǎn)換成 UTC 時間;
USE_TZ = True

# 靜態(tài)文件路徑
STATIC_URL = '/static/'

App

    接下來要引入一個APP的概念,舉個例子我們需要開發(fā)一個電商網(wǎng)站,那么產(chǎn)品列表、購物車、下單等等這都是不同的業(yè)務(wù)線,我們可以把每條業(yè)務(wù)線都看做一個App。

創(chuàng)建App

創(chuàng)建一個名為app_demo的應(yīng)用,  在終端項目目錄下執(zhí)行

 python3 manage.py startapp app_demo

再次tree 查看目錄結(jié)構(gòu) 

├── 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目錄結(jié)構(gòu)

    admin:對應(yīng)應(yīng)用后臺管理配置文件

    apps:對應(yīng)應(yīng)用的配置文件

    models:數(shù)據(jù)模塊,用于設(shè)計數(shù)據(jù)庫等

    tests:編寫測試腳本

    views:視圖層,直接和瀏覽器進(jìn)行交互

    每次新建一個App我們需要將其在settings.py文件中的INSTALLED_APPS里進(jìn)行注冊,這樣程序才能夠找到這個服務(wù)

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app_demo', # 注冊新創(chuàng)建的應(yīng)用app
]

HelloWorld

    helloworld任何一門語言的開始,所以,我們?nèi)腴T的帶個程序也從這里開始。前面說過Django框架式MVT結(jié)構(gòu)的,這里由于沒有用到數(shù)據(jù)和模板所以只需要在V(視圖層)進(jìn)行coding。

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

from django.http import HttpResponse
"""
 django.http模塊中定義了HttpResponse 對象的API
 作用:不需要調(diào)用模板直接返回數(shù)據(jù)
 HttpResponse屬性:
    content: 返回內(nèi)容,字符串類型
    charset: 響應(yīng)的編碼字符集
    status_code: HTTP響應(yīng)的狀態(tài)碼
"""

"""
hello 為一個視圖函數(shù),每個視圖函數(shù)必須第一個參數(shù)為request。哪怕用不到request。
request是django.http.HttpRequest的一個實例
"""
def hello(request):
    return HttpResponse('Hello World')

    視圖層寫完,最終通過HttpResponse將'Hello World'進(jìn)行響應(yīng)。

    前面提到過urls是用來聲明請求url的映射關(guān)系。也就是程序通過urls里的配置來找到我們寫的這個view。

# 導(dǎo)入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),第一個元素是匹配的字符串,第二個元素為相對應(yīng)的視圖模塊。

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

再來個栗子

    app_demo的views模塊中繼續(xù)添加(和前面寫的hello視圖同文件)

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

    setting中app_demo這個app前面已經(jīng)注冊過,所以不需要再次注冊,在urls配置他們的關(guān)系映射

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字段的值范圍為非數(shù)字的字符即:a-z A-Z 漢字、(?P<age>\d+) 表示age字段只能是數(shù)字

啟動項目

通過執(zhí)行如下命令來啟動項目

python3 manage.py runserver

默認(rèn)端口號為:8000,當(dāng)8000端口被占用時,我們也可以手動去更換端口,如更換成8080

python3 manage.py runserver 8080

控制臺輸入一下內(nèi)容則表示啟動成功:

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有什么作用

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

Django有什么作用

以上是“Django有什么作用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道!

網(wǎng)站題目:Django有什么作用-創(chuàng)新互聯(lián)
文章源于:http://jinyejixie.com/article36/eggpg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊、微信公眾號、網(wǎng)頁設(shè)計公司、虛擬主機(jī)Google、移動網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司
略阳县| 固镇县| 宣威市| 兴业县| 新乡市| 綦江县| 江口县| 晋州市| 龙泉市| 义乌市| 明水县| 介休市| 屏东市| 江口县| 金门县| 项城市| 铅山县| 富源县| 乐陵市| 灵寿县| 阳春市| 舒兰市| 图片| 宾阳县| 铜鼓县| 铜鼓县| 两当县| 临江市| 濮阳市| 独山县| 北川| 昔阳县| 敦化市| 郑州市| 贵州省| 万山特区| 邵阳县| 高州市| 道孚县| 德阳市| 四会市|