您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Django有什么作用”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Django有什么作用”這篇文章吧。
1、搭建虛擬環境
隨著我們項目的積累,有時候不同項目需要用不到不同版本的包,可能會產生沖突,這時候我們需要一個虛擬環境將每個項目需要的包進行獨立,這樣就能有效避免沖突。
2、安裝MySql
Django支持很多中類型的數據庫,默認配置的sqlite3,在學習過程中我們用到了Mysql
3、安裝Python3、pip、PyCharm
Django2.0和以后的版本不再支持Python2.X,所以我們需要安裝Python3.6版本的解釋器。
pip是一個通用的Python包管理工具,可以對包進行查找、安裝、卸載
PyCharm是一種Python IDE,墻裂推薦。
以上準備工作,小伙伴們可以自行網上查找相關教程。
通過準備工作我們的系統中已經安裝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項目的目錄結構
切換終端到項目所屬目錄,使用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/ 我們可以看到如下界面
瀏覽器輸入 http://localhost:8000/msg/tome/12/
以上是“Django有什么作用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。