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