Django項(xiàng)目怎么請(qǐng)求與響應(yīng)?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。
成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比靜樂網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式靜樂網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋靜樂地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。
一、新建項(xiàng)目
進(jìn)入你期望的項(xiàng)目保存目錄,運(yùn)行下面的命令:
$ django-admin startproject mysite
這將在目錄下生成一個(gè)mysite目錄,也就是你的這個(gè)Django項(xiàng)目的根目錄。它包含了一系列自動(dòng)生成的目錄和文件,具備各自專有的用途。
注意:在給項(xiàng)目命名的時(shí)候必須避開Django和Python的保留關(guān)鍵字,比如“django”,“test”等,否則會(huì)引起沖突和莫名的錯(cuò)誤。對(duì)于mysite的放置位置,不建議放在傳統(tǒng)的/var/wwww目錄下,它會(huì)具有一定的數(shù)據(jù)暴露危險(xiǎn),因此Django建議你將項(xiàng)目文件放在例如/home/mycode類似的位置。
一個(gè)新建立的項(xiàng)目結(jié)構(gòu)大概如下:
mysite/ manage.py mysite/ __init__.py settings.py urls.py wsgi.py
各文件和目錄解釋:
外層的mysite/目錄與Django無關(guān),只是你項(xiàng)目的容器,可以任意重命名。manage.py:一個(gè)命令行工具,用于與Django進(jìn)行不同方式的交互腳本,非常重要!內(nèi)層的mysite/目錄是真正的項(xiàng)目文件包裹目錄,它的名字是你引用內(nèi)部文件的包名,例如:mysite.urls。mysite/__init__.py:一個(gè)定義包的空文件。mysite/settings.py:項(xiàng)目的主配置文件,非常重要!mysite/urls.py:路由文件,所有的任務(wù)都是從這里開始分配,相當(dāng)于Django驅(qū)動(dòng)站點(diǎn)的內(nèi)容表格,非常重要!mysite/wsgi.py:一個(gè)基于WSGI的web服務(wù)器進(jìn)入點(diǎn),提供底層的網(wǎng)絡(luò)通信功能,通常不用關(guān)心。
PS:這一部分,我們可以在Pycharm環(huán)境下進(jìn)行,參考上節(jié)內(nèi)容。
二、 啟動(dòng)開發(fā)服務(wù)器
進(jìn)入mystie項(xiàng)目的根目錄,輸入下面的命令:
$ python manage.py runserver
你會(huì)看到下面的提示,這表明Django的開發(fā)服務(wù)器已經(jīng)啟動(dòng),開始提供Web服務(wù)了:
Performing system checks... System check identified no issues (0 silenced). You have unapplied migrations; your app may not work properly until they are applied. Run 'python manage.py migrate' to apply them. 四月 17, 2019 - 15:50:53 Django version 2.2, using settings 'mysite.settings' Starting development server at [http://127.0.0.1:8000/](http://127.0.0.1:8000/) Quit the server with CONTROL-C.</pre>
Django提供了一個(gè)用于開發(fā)的web服務(wù)器,使你無需配置一個(gè)類似Ngnix的生產(chǎn)服務(wù)器,就能讓站點(diǎn)運(yùn)行起來。這是一個(gè)由Python編寫的輕量級(jí)服務(wù)器,簡(jiǎn)易并且不安全,因此不要將它用于生產(chǎn)環(huán)境。
打開瀏覽器,訪問http://127.0.0.1:8000/,你將看到Django的火箭歡迎界面,一切OK!
Django的開發(fā)服務(wù)器(以后簡(jiǎn)稱服務(wù)器)默認(rèn)運(yùn)行在內(nèi)部的8000端口,如果你想指定端口,請(qǐng)?jiān)诿钪酗@示給出:
$ python manage.py runserver 8080
如果想修改服務(wù)器的ip地址,請(qǐng)按下面的方式運(yùn)行命令,比如:
$ python manage.py runserver 0:8000
0 是 0.0.0.0 的簡(jiǎn)寫,Django將運(yùn)行在0.0.0.0:8000上,整個(gè)局域網(wǎng)內(nèi)都將可以訪問站點(diǎn),而不只是是本機(jī)。
注意: Django的開發(fā)服務(wù)器具有自動(dòng)重載功能,當(dāng)你的代碼有修改,每隔一段時(shí)間服務(wù)器將自動(dòng)更新。但是,有一些例如增加文件的動(dòng)作,不會(huì)觸發(fā)服務(wù)器重載,這時(shí)就需要你自己手動(dòng)重啟。
PS: 這一步操作在Pycharm里只需要簡(jiǎn)單地按下綠色三角:
三、 創(chuàng)建投票應(yīng)用(app)
在 Django 中,每一個(gè)應(yīng)用(app)都是一個(gè) Python 包,并且遵循著相同的約定。Django 自帶一個(gè)工具,可以幫你生成應(yīng)用的基礎(chǔ)目錄結(jié)構(gòu)。
app應(yīng)用與project項(xiàng)目的區(qū)別:
一個(gè)app實(shí)現(xiàn)某個(gè)功能,比如博客、公共檔案數(shù)據(jù)庫(kù)或者簡(jiǎn)單的投票系統(tǒng);一個(gè)project是配置文件和多個(gè)app的集合,這些app組合成整個(gè)站點(diǎn);一個(gè)project可以包含多個(gè)app;一個(gè)app可以屬于多個(gè)project!
app的存放位置可以是任何地點(diǎn),但是通常都將它們放在與manage.py腳本同級(jí)的目錄下,這樣方便導(dǎo)入文件。
進(jìn)入mysite項(xiàng)目根目錄,確保與manage.py文件處于同一級(jí),輸入下述命令:
$ python manage.py startapp polls
系統(tǒng)會(huì)自動(dòng)生成 polls應(yīng)用的目錄,其結(jié)構(gòu)如下:
polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py views.py
在Pycharm中,沒有可以創(chuàng)建app的圖形化按鈕,需要在下方的Terminal終端中輸入命令:
python manage.py startapp polls
這樣也能創(chuàng)建polls應(yīng)用。
通過前面在Pycharm中創(chuàng)建工程的方式有個(gè)方便之處,點(diǎn)擊Terminal后,會(huì)自動(dòng)進(jìn)入虛擬環(huán)境。
四、編寫第一個(gè)視圖
在polls/views.py文件中,編寫代碼:
from django.http import HttpResponsedef index(request): return HttpResponse("Hello, world. You're at the polls index.")
為了調(diào)用該視圖,我們還需要編寫urlconf,也就是路由路徑?,F(xiàn)在,在polls目錄中新建一個(gè)文件,名字為urls.py,在其中輸入代碼如下:
from django.urls import pathfrom . import viewsurlpatterns = [ path('', views.index, name='index'),]
此時(shí),目錄的文件結(jié)構(gòu)是這樣的:
polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py urls.py views.py
我們先不用深究urls.py中代碼的具體含義。
接下來,在項(xiàng)目的主urls.py文件中添加urlpattern條目,指向我們剛才建立的polls這個(gè)app獨(dú)有的urls文件,這里需要導(dǎo)入include模塊。打開mysite/urls.py文件,代碼如下:
from django.contrib import adminfrom django.urls import include, pathurlpatterns = [ path('polls/', include('polls.urls')), path('admin/', admin.site.urls),]
include語法相當(dāng)于多級(jí)路由,它把接收到的url地址去除與此項(xiàng)匹配的部分,將剩下的字符串傳遞給下一級(jí)路由urlconf進(jìn)行判斷。在路由的章節(jié),有更加詳細(xì)的用法指導(dǎo)。
include的背后是一種即插即用的思想。項(xiàng)目根路由不關(guān)心具體app的路由策略,只管往指定的二級(jí)路由轉(zhuǎn)發(fā),實(shí)現(xiàn)了應(yīng)用解耦。app所屬的二級(jí)路由可以根據(jù)自己的需要隨意編寫,不會(huì)和其它的app路由發(fā)生沖突。app目錄可以放置在任何位置,而不用修改路由。這是軟件設(shè)計(jì)里很常見的一種模式。
建議:除了admin路由外,盡量給每個(gè)app設(shè)計(jì)自己獨(dú)立的二級(jí)路由。
好了,路由設(shè)置成功后,啟動(dòng)服務(wù)器,然后在瀏覽器中訪問地址http://localhost:8000/polls/。一切正常的話,你將看到“Hello, world. You’re at the polls index.”
path()方法:
路由系統(tǒng)中最重要的path()方法可以接收4個(gè)參數(shù),其中2個(gè)是必須的:route和view,以及2個(gè)可選的參數(shù):kwargs和name。
route:
route 是一個(gè)匹配 URL 的準(zhǔn)則(類似正則表達(dá)式)。當(dāng) Django 響應(yīng)一個(gè)請(qǐng)求時(shí),它會(huì)從 urlpatterns 的第一項(xiàng)開始,按順序依次匹配列表中的項(xiàng),直到找到匹配的項(xiàng),然后執(zhí)行該條目映射的視圖函數(shù)或下級(jí)路由,其后的條目將不再繼續(xù)匹配。因此,url路由的編寫順序非常重要!
需要注意的是,route不會(huì)匹配 GET 和 POST 參數(shù)或域名。例如,URLconf 在處理請(qǐng)求 https://www.example.com/myapp/時(shí),它會(huì)嘗試匹配 myapp/。處理請(qǐng)求 https://www.example.com/myapp/?page=3 時(shí),也只會(huì)嘗試匹配 myapp/。
view:
view指的是處理當(dāng)前url請(qǐng)求的視圖函數(shù)。當(dāng)Django匹配到某個(gè)路由條目時(shí),自動(dòng)將封裝的HttpRequest對(duì)象作為第一個(gè)參數(shù),被“捕獲”的參數(shù)以關(guān)鍵字參數(shù)的形式,傳遞給該條目指定的視圖view。
kwargs:
任意數(shù)量的關(guān)鍵字參數(shù)可以作為一個(gè)字典傳遞給目標(biāo)視圖。
name:
對(duì)你的URL進(jìn)行命名,讓你能夠在Django的任意處,尤其是模板內(nèi)顯式地引用它。這是一個(gè)非常強(qiáng)大的功能,相當(dāng)于給URL取了個(gè)全局變量名,不會(huì)將url匹配地址寫死。
關(guān)于Django項(xiàng)目怎么請(qǐng)求與響應(yīng)問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
本文題目:Django項(xiàng)目怎么請(qǐng)求與響應(yīng)
新聞來源:http://chinadenli.net/article28/pgoejp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、企業(yè)建站、建站公司、品牌網(wǎng)站制作、、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)