python之路_django路由配置及模板
URL配置(URLconf)就像Django 所支撐網(wǎng)站的目錄。它的本質(zhì)是URL與要為該URL調(diào)用的視圖函數(shù)之間的映射表;你就是以這種方式告訴Django,對于這個URL調(diào)用這段代碼,對于那個URL調(diào)用那段代碼。
'''urlpatterns = [url(正則表達式, views視圖函數(shù),參數(shù),別名), ]參數(shù)說明:一個正則表達式字符串一個可調(diào)用對象,通常為一個視圖函數(shù)或一個指定視圖函數(shù)路徑的字符串可選的要傳遞給視圖函數(shù)的默認參數(shù)(字典形式)一個可選的name參數(shù)'''一、url的反向解析
如上述,url中的正則表達式即為請求的路徑,根據(jù)路徑匹配執(zhí)行對應的視圖函數(shù),如下,當我們請求路徑符合正則表達式要求,就會執(zhí)行對應的login函數(shù):
其中l(wèi)ogin函數(shù)為:
login.html文件為:
根據(jù)以上我們所寫的代碼邏輯,當通過get請求/login/路徑時,我們執(zhí)行符合此請求路徑對應的login()函數(shù),函數(shù)渲染一個login.htl的登錄頁面,當用戶驗證完信息點擊提交按鈕時,再次以post形式請求/login/對應的login()函數(shù)。
但是,在某些情況下,我們需要更改請求路徑的正則表達式,即更換一個請求路徑,這時候我們就需要對上述的url中的正則表達式和login.html中的提交路徑同時進行更改成我們想要的,但是當我們有很多個文件和位置都有請求/login/的時候,我們一個個的手動的更改顯然不是很合理。這就需要用到反向解析,也就是url中別名參數(shù)的作用,具體實例如下:
以上即稱為反向解析,無論url中請求路徑的如何更改,只要別名不改,程序中對此函數(shù)的請求都可以通過別名反向解析的形式找到。
二、Including other URLconfs
django項目中創(chuàng)建應用的命令為:
python manage.py startapp app01(app01為項目名)在django項目創(chuàng)建后,會有一個url.py文件,用于映射不同請求路徑對應的函數(shù),但是當我們一個django項目中有很多應用的話,各個項目的url的映射關(guān)系均放在此文件中顯然不妥,不利于代碼間的解耦。此時需要在此url文件中設(shè)置Including other URLconfs,設(shè)置后各應用對應的url映射關(guān)系就可以放在應用自己目錄下urls.py文件中。如下:
此情況訪問應用下路徑映射函數(shù)的的方式如下例所示:
三、正則字符串參數(shù)
1、無名分組
通過在正則字符中使用一對括號,就可以實現(xiàn)分組,并可以獲得分組的參數(shù),如下例:
url(r'^articles/(\d{4})/(\d{2})/$', views.articles2), #articles2(request,組1參數(shù),組2參數(shù))當請求路徑為:http://127.0.0.1:8000/app01/articles/2004/12/,路徑符合上述正則表達式字符串,執(zhí)行articles2(request,2014,12)函數(shù),即要求定義articles2函數(shù)時候必須要接收三個參數(shù),映射過程是按照位置進行傳參,函數(shù)實例如下:
def articles2(request,year,month):return HttpResponse(year+"---"+month)2、有名分組
上面的示例使用簡單的、沒有命名的正則表達式組(通過圓括號)來捕獲URL 中的值并以位置 參數(shù)傳遞給視圖。在更高級的用法中,可以使用命名的正則表達式組來捕獲URL 中的值并以關(guān)鍵字 參數(shù)傳遞給視圖。在Python 正則表達式中,命名正則表達式組的語法是(?P<name>pattern),其中name?是組的名稱,pattern?是要匹配的模式。
url(r'^articles/(?P<y>\d{4})/(?P<m>\d{2})/$', views.articles3) #articles3(request,y=對應參數(shù),m=對應參數(shù))當請求路徑為:http://127.0.0.1:8000/app01/articles/2004/12/,路徑符合上述正則表達式字符串,執(zhí)行articles3(request,y=2014,m=12)函數(shù),即要求定義articles3函數(shù)時必須要接收三個參數(shù),且參數(shù)必須為y和m,映射過程是按照關(guān)鍵字進行傳參,函數(shù)實例如下:
def articles3(request,y,m): #參數(shù)y和m必須與分組名一致,因為是按照關(guān)鍵字傳參,位置隨意return HttpResponse(y+"-----"+m)四、redirect函數(shù)
redirect()函數(shù)也稱為重定向函數(shù),現(xiàn)在以第一部分中登陸實例為講述其執(zhí)行過程:
第一次網(wǎng)頁請求:請求url: http://127.0.0.1:8000/login/ 請求類型:GET 無請求數(shù)據(jù)login/-------> views.login------>login()響應到一個login.html頁面第二次按鈕提交:請求url: http://127.0.0.1:8000/login.html/ 請求類型:POST 有請求數(shù)據(jù) {"user":"alex","pwd":"123"}login.html/-------> views.login------>login()響應的return redirect("/index/")到瀏覽器,通知瀏覽器再發(fā)送請求:"/index/"請求url: http://127.0.0.1:8000/index/ 請求類型:GET 沒請求數(shù)據(jù)index/ --->url(r'^index/', views.index),---->index()響應一個index.html
有上述過程分析可知,重定向函數(shù)redirect在重定向的過程中實際是接受到兩次響應,第一次通過響應告訴瀏覽器重新發(fā)送請求到需要重定向的路徑,第二次是瀏覽器發(fā)送重定向路徑請求后得到響應結(jié)果。
?五、模板層
1、模板語法之變量
在 Django 模板中遍歷復雜數(shù)據(jù)結(jié)構(gòu)的關(guān)鍵是句點字符 ,不同數(shù)據(jù)類型的數(shù)據(jù)通過據(jù)點字符取值的方式如下例所示:
def index(request):lis=[111,222,333]dic = {"name": "alex"}class Person():def __init__(self,name,age):self.name=nameself.age=agedef dream(self):return ("dream.....")alex=Person(name="alex",age=34)egon=Person(name="egon",age=9000)nacha=Person(name="nacha",age=3)person_list=[alex,egon,nacha]return render(request,"index.html",{"lis":lis,"dic":dic,"person_list":person_list})index.html文件:
<body> <hr> <p>{{lis.2 }}</p> //通過索引取,結(jié)果:222 <p>{{ dic.name}}</p> //通過key取,結(jié)果:alex <p>{{ person_list.1.name }}</p> //通過索引取到對象,通過對象屬性取到屬性值 <p>{{ person_list.1.age }}</p><hr> {% for person in person_list %} //通過循環(huán)取到對象,根據(jù)對象屬性取到屬性值 <p>{{ person.name }},{{ person.age }}</p> {% endfor %} <hr> {{ person_list.1.dream }} //可以取到對象的方法,前提是此方法不需要參數(shù),且有返回值,且取值時不需要括號 </body>?2、模板語法之過濾
3、模板之標簽
在之前章節(jié)中我們分散的介紹了部分模板標簽,如for標簽、for...empty標簽、if標簽,這里不再對其贅述,重點補充介紹csrf_token標簽。這個標簽用于跨站請求偽造保護,以登錄實例介紹如下:
(1)form表單跳轉(zhuǎn)登錄:
如上登錄流程,我們在完成一次完整的登錄過程中發(fā)生兩次請求,第一次請求login()結(jié)果是渲染出登錄頁面,第二次則是通過提交按鈕通過判斷執(zhí)行登錄成功后的跳轉(zhuǎn),但是跨站請求偽造是發(fā)生在我們點擊提交按鈕的過程,即這種跨站請求偽造實際只有一次請求。django框架中為了解決此問題,即跨站請求偽造保護,便出現(xiàn)了{% csrf_token %}標簽,它的作用是,在登錄第一次請求渲染login.html文件時,便被渲染成一個隱藏的input標簽,此input標簽還有name(固定值:csrfmiddlewaretoken)和value值(隨機的生成的字符串),用于第二次提交請求時的身份驗證,因為跨站請求偽造只有第二步中請求,所以他并沒有這樣的身份標識,所以完美的解決了此問題。
若登錄頁面的form表單沒有{% csrf_token %}標簽,我們點擊提交按鈕時,便會發(fā)生如下禁止提示,無法驗證登錄:
(2)ajax跳轉(zhuǎn)登錄
login()函數(shù)為:
def login(request):if request.is_ajax(): #判斷是否為ajax請求user=request.POST.get("user")pwd=request.POST.get("pwd")loginResponse={"user":None,"error_msg":None}if user=="alex" and pwd=="123":loginResponse["user"]=userelse:loginResponse["error_msg"]="username or password is wrong!"import jsonreturn HttpResponse(json.dumps(loginResponse))return render(request,"login.html")login.html文件為:
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Title</title></head> <body> {% csrf_token %} <p>姓名:<input type="text" id="user"></p> <p>密碼:<input type="password" id="pwd"></p> <button>click</button><span class="error"></span><script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script> <script>$("button").on("click",function () {$.ajax({url:"/login/",type:"POST",data:{user:$("#user").val(),pwd:$("#pwd").val(),csrfmiddlewaretoken:$("[name='csrfmiddlewaretoken']").val() //需主動將隱藏input值發(fā)送過去,方便身份驗證 },success:function (data) {var data=JSON.parse(data);if (data.user){location.href="/index/" // 跳轉(zhuǎn)到首頁 }else {$(".error").html(data.error_msg).css("color","red"); // 設(shè)置定時器 setTimeout(function () {$(".error").html("")},2000)}}})}) </script> </body> </html>以上兩種登錄方式中,第一種中{% csrf_token %} ?標簽生成的隱藏標簽因為是在form表單中,所以當點擊提交按鈕以后會被一起發(fā)送到后端,第二種因為并不存在form表單,所以需要取出來放在ajax數(shù)據(jù)中發(fā)送至后端。
4、模板之繼承
在前面章節(jié),我們介紹了模板繼承相關(guān)內(nèi)容,此處我們不在贅述,主要補充一點內(nèi)容,如下:
母板base.html文件部分內(nèi)容:
{% block sidebar %}<ul><li><a href="/">Home</a></li><li><a href="/blog/">Blog</a></li></ul>{% endblock %}如果在繼承文件中我們即想保留母板中已經(jīng)存在的那部分內(nèi)容,又想實現(xiàn)新增內(nèi)容,實現(xiàn)方式如下:
{% block sidebar %}{{ block.super}} //可以讓母板此塊下的內(nèi)容保留<p>3333</p>{% endblock %}?
?
?
?
?
?
?
?
轉(zhuǎn)載于:https://www.cnblogs.com/seven-007/p/7988429.html
總結(jié)
以上是生活随笔為你收集整理的python之路_django路由配置及模板的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第6次组会
- 下一篇: Python赋值、浅拷贝、深拷贝