Python Django基礎(chǔ)二之URL路由系統(tǒng)
MVC和MTV框架
MVC
Web服務(wù)器開(kāi)發(fā)領(lǐng)域里著名的MVC模式,所謂MVC就是把Web應(yīng)用分為模型(M),控制器(C)和視圖(V)三層,他們之間以一種插件式的、松耦合的方式連接在一起,模型負(fù)責(zé)業(yè)務(wù)對(duì)象與數(shù)據(jù)庫(kù)的映射(ORM),視圖負(fù)責(zé)與用戶(hù)的交互(頁(yè)面),控制器接受用戶(hù)的輸入調(diào)用模型和視圖完成用戶(hù)的請(qǐng)求,其示意圖如下所示:
| M:models數(shù)據(jù)庫(kù)相關(guān);V:views視圖相關(guān) C:controller控制器 url分發(fā) |
MTV
Django的MTV模式本質(zhì)上和MVC是一樣的,也是為了各組件間保持松耦合關(guān)系,只是定義上有些許不同,Django的MTV分別是值:
- M 代表模型(Model): 負(fù)責(zé)業(yè)務(wù)對(duì)象和數(shù)據(jù)庫(kù)的關(guān)系映射(ORM)。
- T 代表模板 (Template):負(fù)責(zé)如何把頁(yè)面展示給用戶(hù)(html)。
- V 代表視圖(View): 負(fù)責(zé)業(yè)務(wù)邏輯,并在適當(dāng)時(shí)候調(diào)用Model和Template。
除了以上三層之外,還需要一個(gè)URL分發(fā)器,它的作用是將一個(gè)個(gè)URL的頁(yè)面請(qǐng)求分發(fā)給不同的View處理,View再調(diào)用相應(yīng)的Model和Template,MTV的響應(yīng)模式如下所示:
| M:models數(shù)據(jù)庫(kù)相關(guān); T:templates模板 html文件 ;V:views視圖相關(guān) + url分發(fā) |
一般是用戶(hù)通過(guò)瀏覽器向我們的服務(wù)器發(fā)起一個(gè)請(qǐng)求(request),這個(gè)請(qǐng)求回去訪(fǎng)問(wèn)視圖函數(shù),(如果不涉及到數(shù)據(jù)調(diào)用,那么這個(gè)時(shí)候視圖函數(shù)返回一個(gè)模板也就是一個(gè)網(wǎng)頁(yè)給用戶(hù)),視圖函數(shù)調(diào)用模型,模型去數(shù)據(jù)庫(kù)查找數(shù)據(jù),然后逐級(jí)返回,視圖函數(shù)把返回的數(shù)據(jù)填充到模板中空格中,最后返回網(wǎng)頁(yè)給用戶(hù)。
Django下載安裝
1、下載Django:
pip3 install django==1.11.9
2、創(chuàng)建一個(gè)django project
django-admin startproject first_project #創(chuàng)建了一個(gè)名為"first_project"的Django 項(xiàng)目:
3、啟動(dòng)django項(xiàng)目
python manage.py runserver 127.0.0.1:8001 python manage.py runserver 8001 #本機(jī)就不用寫(xiě)ip地址了 python manage.py runserver #如果連端口都沒(méi)寫(xiě),默認(rèn)是本機(jī)的8000端口
這樣我們的django就啟動(dòng)起來(lái)了,只不過(guò)什么邏輯也沒(méi)有呢!
當(dāng)我們?cè)L問(wèn):http://127.0.0.1:8080/時(shí)就可以看到:
當(dāng)前目錄下會(huì)生成first_project的工程,目錄結(jié)構(gòu)如下:(大家注意昂,pip下載下來(lái)的django你就理解成一個(gè)模塊,而不是django項(xiàng)目,這個(gè)模塊可以幫我們創(chuàng)建django項(xiàng)目)
- manage.py ----- Django項(xiàng)目里面的工具,通過(guò)它可以調(diào)用django shell和數(shù)據(jù)庫(kù),啟動(dòng)關(guān)閉項(xiàng)目與項(xiàng)目交互等,不管你將框架分了幾個(gè)文件,必然有一個(gè)啟動(dòng)文件,其實(shí)他們本身就是一個(gè)文件。
- settings.py ---- 包含了項(xiàng)目的默認(rèn)設(shè)置,包括數(shù)據(jù)庫(kù)信息,調(diào)試標(biāo)志以及其他一些工作的變量。
- urls.py ----- 負(fù)責(zé)把URL模式映射到應(yīng)用程序。
- wsgi.py ---- runserver命令就使用wsgiref模塊做簡(jiǎn)單的web server,后面會(huì)看到renserver命令,所有與socket相關(guān)的內(nèi)容都在這個(gè)文件里面了,目前不需要關(guān)注它。
創(chuàng)建app
python manage.py startapp app名稱(chēng) 在settings中配置 'app01.apps.App01Config' 或者'app01'
pycharm創(chuàng)建django項(xiàng)目
1.file -->new project
2.Django -->項(xiàng)目名稱(chēng) -->選擇Python選擇器 -->應(yīng)用名稱(chēng)(業(yè)務(wù)邏輯相關(guān)的程序)
項(xiàng)目目錄結(jié)構(gòu):
寫(xiě)一個(gè)Django項(xiàng)目:
做一個(gè)登錄頁(yè)面的Web項(xiàng)目,瀏覽器輸入網(wǎng)址得到一個(gè)web頁(yè)面 輸入網(wǎng)址:127.0.0.1:8000/login/ 1.創(chuàng)建項(xiàng)目 second_pro 2.創(chuàng)建app app02 3.urls.py from django.conf.urls import url from django.contrib import admin from app02 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^index/', views.index), ] 4.views.py 寫(xiě)邏輯視圖 from django.shortcuts import render,HttpResponse # Create your views here. def index(request): # print(request.method) #獲取請(qǐng)求方式GET或POST if request.method=='GET': return render(request,'login.html') #回復(fù)一個(gè)頁(yè)面 else: username=request.POST.get('username') #獲取post數(shù)據(jù) password=request.POST.get('password') if username=='anwen' and password=='123': return HttpResponse('登錄成功!') #回復(fù)字符串 else: return HttpResponse('登錄失敗!') 5.在templates文件夾中創(chuàng)建login.html 頁(yè)面 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>login</title> </head> <body> <form action="/index/" method="post"> <div> 用戶(hù)名:<input type="text" name="username"> </div> <div> 密碼: <input type="text" name="password"> </div> <input type="submit"> </form> </body> </html> 注意: 1.urls.py 里面需要注意的問(wèn)題: url(r'index/',views.index) #第一個(gè)參數(shù)路徑正則字符串,第二個(gè)參數(shù)對(duì)應(yīng)的視圖邏輯 2. def index(request): # print(request.method) #獲取請(qǐng)求方式GET或POST request.GET ---GET請(qǐng)求發(fā)送來(lái)的所有數(shù)據(jù),queryDict類(lèi)型 request.POST ---POST請(qǐng)求發(fā)送來(lái)的所有數(shù)據(jù),queryDict類(lèi)型 request.GET.get('username') #獲取get數(shù)據(jù) request.POST.get('username') #獲取post數(shù)據(jù) return render(request,'login.html') #回復(fù)一個(gè)頁(yè)面 return HttpResponse('登錄成功!') #回復(fù)字符串
get請(qǐng)求獲取數(shù)據(jù):
def index(request): print(retuest.GET) #<QueryDict:{'username':'anwen','password':['123']}> username=request.GET.get('username') password=request.GET.get('password') print(username,password) if username=='anwen' and password =='123': return HttpResponse('登錄成功') else: return HttpResponse('登錄失敗')
post請(qǐng)求提交數(shù)據(jù)時(shí)關(guān)掉一個(gè)認(rèn)證機(jī)制,settings配置文件中
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', # 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ]
URL配置
無(wú)名分組
url(r'^books/(\d{4})/',views.books) #(\d{4})
位置參數(shù)
url(r'^books/(\d{4})/',views.year_books) #匹配年份 url(r'^books/(\d{4})/(\d{1,2})/',views_year_month_books) #匹配年份和月份 #http://127.0.0.1:8000/books/2019/2/ 視圖: def year_month_books(request,year,month): #位置參數(shù) ,第一個(gè)參數(shù)接收的是無(wú)名分組路徑中匹配到的第一個(gè)的分組數(shù)據(jù),第二個(gè)參數(shù)接收到的就是無(wú)名分組中路徑中匹配到的第二個(gè)分組數(shù)據(jù) print(year,month)
分組命名匹配
在Python的正則表達(dá)式中,分組命名正則表達(dá)式組的語(yǔ)法是(?P<name>pattern),其中name是組的名稱(chēng),pattern是要匹配的模式。使用命名組的重寫(xiě) url(r'^books/(?p<year>\d{4})/(?p<month>\d{1,2}/',views.year_month_books)#匹配年份和月份 def year_month)books(request,.month,year):#形參名稱(chēng)要和url中的分組名稱(chēng)對(duì)應(yīng),參數(shù)位置沒(méi)有順序要求 print(year,month)
默認(rèn)值
#urls.py中 from django.conf.url import url from . import views urlpatterns=[ # 視圖函數(shù)中指定默認(rèn)值,如果第一個(gè)模式匹配上了,year_books()函數(shù)將使用其默認(rèn)參數(shù)num=“1”,如果第二個(gè)模式匹配,year_books()將使用正則表達(dá)式捕獲到的num值。 url(r'^books/$', views.year_books), url(r'^books/(?P<num>\d{4})', views.year_books), ] #views.py中 def pag(request,num='10'): pass
注意事項(xiàng)
- urlpatterns中的元素按照書(shū)寫(xiě)順序從上往下逐一匹配正則表達(dá)式,一旦匹配成功則不再繼續(xù)。
- 若要從URL中捕獲一個(gè)值,只需要在它周?chē)胖靡粚?duì)圓括號(hào)(分組匹配)。
- 不需要添加一個(gè)前導(dǎo)的反斜杠(也就是寫(xiě)在正則最前面的那個(gè)/),因?yàn)槊總€(gè)URL 都有。例如,應(yīng)該是^articles 而不是 ^/articles。
- 每個(gè)正則表達(dá)式前面的'r' 是可選的但是建議加上。^articles& 以什么結(jié)尾,以什么開(kāi)頭,嚴(yán)格限制路徑
url末尾加'/'補(bǔ)充說(shuō)明
#是否開(kāi)啟URL訪(fǎng)問(wèn)地址后面不為/跳轉(zhuǎn)至帶有/的路徑的配置項(xiàng) APPEND_SLASH=True Django settings.py配置文件中默認(rèn)沒(méi)有 APPEND_SLASH 這個(gè)參數(shù),但 Django 默認(rèn)這個(gè)參數(shù)為 APPEND_SLASH = True。 其作用就是自動(dòng)在網(wǎng)址結(jié)尾加'/'。其效果就是:我們定義了urls.py: from django.conf.urls import url from app01 import views urlpatterns = [ url(r'^blog/$', views.blog), ] 訪(fǎng)問(wèn) http://www.example.com/blog 時(shí),默認(rèn)將網(wǎng)址自動(dòng)轉(zhuǎn)換為 http://www.example/com/blog/ 。 如果在settings.py中設(shè)置了 APPEND_SLASH=False,此時(shí)我們?cè)僬?qǐng)求 http://www.example.com/blog 時(shí)就會(huì)提示找不到頁(yè)面。
url路由分發(fā)之include
#項(xiàng)目文件夾下的urls.py文件中的url寫(xiě)法: from django.conf.urls import url,include from django.contrib import admin from app01 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), #首頁(yè) url(r'^$', views.base), url(r'^app01/', include('app01.urls')), url(r'^app02/', include('app02.urls')), ] #app01下urls.py內(nèi)容寫(xiě)法 from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^$', views.app01base), url(r'^index/', views.index), ] #app02下urls.py內(nèi)容寫(xiě)法 from django.conf.urls import url from django.contrib import admin from app02 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^$', views.app02base), url(r'^home/', views.home), ]
總結(jié)
以上所述是小編給大家介紹的Python Django基礎(chǔ)二之URL路由系統(tǒng) ,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- Python中Django框架利用url來(lái)控制登錄的方法
- Python的Django框架中從url中捕捉文本的方法
- Python的Django框架中URLconf相關(guān)的一些技巧整理
- 使用url_helper簡(jiǎn)化Python中Django框架的url配置教程
- Python的Django框架中的URL配置與松耦合
- Django命名URL和反向解析URL實(shí)現(xiàn)解析
- Django框架視圖層URL映射與反向解析實(shí)例分析
- django反向解析URL和URL命名空間的方法
- Python Django框架url反向解析實(shí)現(xiàn)動(dòng)態(tài)生成對(duì)應(yīng)的url鏈接示例
相關(guān)文章
python項(xiàng)目對(duì)接釘釘SDK的實(shí)現(xiàn)
這篇文章主要介紹了python項(xiàng)目對(duì)接釘釘SDK的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python機(jī)器學(xué)習(xí)性能度量利用鳶尾花數(shù)據(jù)繪制P-R曲線(xiàn)
這篇文章主要為大家介紹了Python機(jī)器學(xué)習(xí)性能度量利用鳶尾花數(shù)據(jù)繪制P-R曲線(xiàn)示例學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02使用keras實(shí)現(xiàn)densenet和Xception的模型融合
這篇文章主要介紹了使用keras實(shí)現(xiàn)densenet和Xception的模型融合,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05Django報(bào)錯(cuò)TemplateDoesNotExist的問(wèn)題及解決
這篇文章主要介紹了Django報(bào)錯(cuò)TemplateDoesNotExist的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08jupyter note 實(shí)現(xiàn)將數(shù)據(jù)保存為word
這篇文章主要介紹了jupyter note 實(shí)現(xiàn)將數(shù)據(jù)保存為word,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04