2-第一個Django程序


第一個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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM