從本章節開始將經過實現一個投票應用程序,來讓用戶逐步的瞭解Django。這個程序由兩步分組成:html
本文繼承前一篇章節的環境(centos 7 python3.6.2 Django2.2)進行演示:python
1.1 建立存放項目的目錄web
[root@localhost ~]# cd /opt/ [root@localhost opt]# mkdir source_project # 建立Django項目存放目錄
1.2 建立Django項目sql
[root@localhost opt]# cd source_project/ [root@localhost source_project]# django-admin startproject mysite # 建立名爲mysite的Django項目
建立完成後會在當前目錄下生成一個mysite的目錄。這個目錄的結構以下:數據庫
mysite項目文檔結構簡介:django
mysite/:項目的根目錄,只是項目的一個容器。它的名字對Django來講並不重要;您能夠將其重命名爲任何您喜歡的名稱。vim
mysite/manage.py:一個命令行實用程序,容許您以各類方式與Django項目交互。您能夠在django-admin和manage .py中閱讀關於manage .py的全部細節。centos
關於django-admin和manage .py參考文檔:https://docs.djangoproject.com/en/2.2/ref/django-admin/服務器
mysite/mysite:這個目錄是一個python包,能夠經過這個包名來導出想要使用的模塊。app
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,若是一切順利你會看到以下所示:
應用程序:是指一個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/