第一個Django程式 從本章節開始將通過實現一個投票應用程式,來讓用戶逐步的瞭解Django。這個程式由兩步分組成: 公共站點,允許用戶訪問進行投票,和查看投票。 站點管理,允許添加,刪除,修改投票信息。 1、創建項目 本文繼承前一篇章節的環境(centos 7 python3.6.2 Djang ...
第一個Django程式
從本章節開始將通過實現一個投票應用程式,來讓用戶逐步的瞭解Django。這個程式由兩步分組成:
- 公共站點,允許用戶訪問進行投票,和查看投票。
- 站點管理,允許添加,刪除,修改投票信息。
1、創建項目
本文繼承前一篇章節的環境(centos 7 python3.6.2 Django2.2)進行演示:
1.1 創建存放項目的目錄
[root@localhost ~]# cd /opt/ [root@localhost opt]# mkdir source_project # 創建Django項目存放目錄
1.2 創建Django項目
[root@localhost opt]# cd source_project/ [root@localhost source_project]# django-admin startproject mysite # 創建名為mysite的Django項目
創建完成後會在當前目錄下生成一個mysite的目錄。這個目錄的結構如下:
mysite項目文檔結構簡介:
mysite/:項目的根目錄,只是項目的一個容器。它的名字對Django來說並不重要;您可以將其重命名為任何您喜歡的名稱。
mysite/manage.py:一個命令行實用程式,允許您以各種方式與Django項目交互。您可以在django-admin和manage .py中閱讀關於manage .py的所有細節。
關於django-admin和manage .py參考文檔:https://docs.djangoproject.com/en/2.2/ref/django-admin/
mysite/mysite:這個目錄是一個python包,可以通過這個包名來導出想要使用的模塊。
mysite/mysite/__init__.py:一個空文件,它告訴Python應該把這個目錄看作一個Python包。
關於python包請參考:https://docs.python.org/3/tutorial/modules.html#tut-packages
mysite/mysite/settings.py:Django項目的配置文件。關於配置文件的一些設置,目前還不打算全部過一遍,用到哪項就對哪項進行設置即可。
settings.py的設置選項可參考:https://docs.djangoproject.com/en/2.2/topics/settings/
settings.py中選項值可參考:https://docs.djangoproject.com/en/2.2/ref/settings/
mysite/mysite/urls.py:django項目的URL路徑。
urls.py的配置信息請參考:https://docs.djangoproject.com/en/2.2/topics/http/urls/
mysite/mysite/wsgi.py:一個與wsgi相容的web伺服器服務於您的項目的入口點。
關於wsgi.py請參考:https://docs.djangoproject.com/en/2.2/howto/deployment/wsgi/
1.3 驗證Django項目是否可以啟動
[root@localhost source_project]# cd mysite/ # 進入到項目目錄中 [root@localhost mysite]# python3 manage.py runserver # 運行項目
你也許會報下麵這個錯誤,但請不要慌張。
我覺得錯誤的問題不在這,繼續往上找我們會看到如下:
我覺得問題可能出現這裡,查看下本機sqlite3資料庫版本,如下:
1.4 安裝sqlite3新版本sqlite3.31。
下載sqlite3新版本
[root@localhost mysite]# wget -P /usr/src/ https://www.sqlite.org/2020/sqlite-autoconf-3310100.tar.gz [root@localhost mysite]# tar -zxvf /usr/src/sqlite-autoconf-3310100.tar.gz -C /opt/ [root@localhost mysite]# cd /opt/sqlite-autoconf-3310100/ # 進入解壓後的包中 [root@localhost sqlite-autoconf-3310100]# ./configure --prefix=/opt/sqlite3310 # 配置安裝選項 [root@localhost sqlite-autoconf-3310100]# make && make install # 編譯 安裝
安裝完成後我們看下該目錄結構如下:
1.5 將新版本的sqlite3.31替換系統自帶的舊版sqlite3.7.17
[root@localhost bin]#whereis sqlite3 # 查找sqlite3命令所在的位置
[root@localhost bin]#cd /opt/sqlite3310/bin [root@localhost bin]# mv /usr/bin/sqlite3 /usr/bin/sqlite37 # 重命名舊版本的sqlite3 [root@localhost bin]# cp sqlite3 /usr/bin/sqlite3 # 將新版本的sqlite3複製到/usr/bin/目錄中 [root@localhost bin]# echo "/opt/sqlite3310/lib/" > /etc/ld.so.conf.d/sqlite3.conf # 指定將新版本的庫位置 [root@localhost bin]# ldconfig # 更新動態鏈接庫
完成上面的所有工作後,我們新安裝的sqlite3.31就可以代替舊版本的sqlite3.7.17。
1.6 驗證sqlite3,31是否正常工作
在python環境中進行驗證
好了,現在我們回到Django項目中運行Django項目,查看是否可以運行。
[root@localhost bin]# cd /opt/source_project/mysite/ [root@localhost mysite]# python3 manage.py runserver # 運行Django項目
如果你看到如下界面,那麼恭喜你,你的項目已經運行起來了。
從上面的圖片我們可以知道,服務運行在本地的127.0.0.1:8000上,此時只能本機進行訪問,區域網的其它主機是不能訪問的。我們可以指定伺服器的IP地址及埠號(如下192.168.10.100:8000),來讓區域網的其它主機進行訪問。
我們在區域網訪問http://192.168.10.100:8000,看看會出現什麼,如果不能訪問,請把本機的防火牆關閉掉,在試試,
[root@localhost mysite]# systemctl stop firewalld # 關閉防火牆
再次訪問http://192.168.10.100:8000,如果一切順利你會看到如下所示:
沒錯,我們的訪問被拒絕了,此時我們需要修改mysite項目中mysite目錄下的settings.py文件了。
[root@localhost mysite]# vim mysite/settings.py
在配置文件中你會看到如下配置選項:
關於ALLOWED_HOSTS的值可以是主機名,也可以是IP地址 # 匹配主機名,如果是完整的主機名如www.example.com,那麼將只匹配www.example.com # 在匹配的過程中不區分大小寫 ALLOWED_HOSTS = ['www.example.com']
# 匹配主機名,如果不是完整的主機名如.example.com,那麼可以匹配所有帶example.com的功能變數名稱,如www.exarmple.com,abc.exarmple.com,a.exarmple.com # 在匹配的過程中不區分大小寫 ALLOWED_HOSTS = ['.example.com']
# 匹配IP地址和主機名 ALLOWED_HOSTS = ['www.example.com','192.168.1.10','192.168.1.200']
# 允許所有主機訪問Django伺服器 ALLOWED_HOSTS = ['*']
我們是初學就將該選項設置為允許所有主機都可以訪問Django伺服器ALLOWED_HOSTS = ['*'],然後再次允許Django伺服器:
root@localhost mysite]# python3 manage.py runserver 192.168.10.100:8000
繼續訪問http://192.168.10.100:8000,如果一切順利你會看到如下所示:
2、創建web應用程式投票App
應用程式:是指一個web應用程式,它是一個功能的集合,如登錄認證,數據展示,還有我們接下來將要寫的投票功能等。
Django項目和應用程式的區別是:項目是一個特定網站的配置和應用程式的集合。應用程式是一個Web應用程式,是一個功能的集合例如,一個Weblog系統、一個公共記錄資料庫或一個簡單的投票應用程式等。
一個項目可以包含多個應用程式。一個應用程式可以在多個項目中。
2.1創建投票app
[root@localhost mysite]# python3 manage.py startapp polls # 創建投票應用
該命令會為我們自動生成應用程式的基本目錄結構,因此您可以專註於編寫代碼,而不是創建目錄。該目錄結構如下:
應用程式polls創建好後,我們需要在該目錄下的views.py中實現投票的功能。
2,2 初識視圖views.py
[root@localhost mysite]# vim polls/views.py # 編輯views.py,在該文件中添加如下代碼 from django.shortcuts import render from django.http import HttpResponse # Create your views here. def index(request): return HttpResponse('這是我的第一個web應用')
這是最簡單的視圖。要調用視圖,我們需要將它映射到一個URL,因為Django伺服器是通過URL路由來尋找視圖的,為此我們需要在polls目錄中創建名為urls.py的文件。
2.3 創建urls.py
[root@localhost mysite]# vim polls/urls.py # 創建URL路由,在路由中寫入如下內容。 from django.urls import path from . import views urlpatterns = [ path('',views.index,name='index'), ]
此時我們的polls應用的目錄結構如下:
雖然我們在polls中設置了路由,但目前該路由僅局限於本polls應用內部,Django主程式還無法找到polls中的URL路由,需要在Django主程式的URL中告訴polls中URL的位置,這樣主程式才能找到polls中的URL。
2.4 在主程式mysite/mysite/urls.py引用polls/urls.py
[root@localhost mysite]# vim mysite/urls.py # 編輯主程式中URL,在主程式的URL中引用polls中的URL from django.contrib import admin from django.urls import path,include urlpatterns = [ path('admin/', admin.site.urls), path('polls/', include('polls.urls')), # 引用polls中的URL,這樣主程式便可以找到polls中的URL了 ]
2.5 驗證
經過上面一系列的操作,現在我們來驗證Django是否可以正常工作。
[root@localhost mysite]# python3 manage.py runserver 192.168.10.100:8000 # 啟動服務
訪問http://192.168.10.100:8000
我們發現和最開始訪問時不一樣了,並且我們發現我們剛剛創建的polls應用也在上面。
我們嘗試訪問http://192.168.10.100:8000/polls/看看會發生什麼
沒錯是我們剛剛在polls/views.py中寫入的內容。這說明我們創建的polls應用可以工作了,雖然沒有實現投票的功能,但離實現投票的功能進了一步。
參考文檔:https://docs.djangoproject.com/en/2.2/intro/tutorial01/