第一個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/
下一章節:在Django中使用mariadb資料庫:https://www.cnblogs.com/caesar-id/p/12319636.html
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/194768.html
標籤:Python
上一篇:HTTPSConnectionPool(host='files.pythonhosted.org', port=443): Read timed out的解決方法
下一篇:Python_內置函式和匿名函式
