国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

在Python的Django框架中包裝視圖函數

2020-01-04 18:01:52
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了在Python的Django框架中包裝視圖函數的方法,即requires_login的相關方法,需要的朋友可以參考下
 

我們最終的視圖技巧利用了一個高級python技術。 假設你發現自己在各個不同視圖里重復了大量代碼,就像 這個例子:
 

  1. def my_view1(request): 
  2.   if not request.user.is_authenticated(): 
  3.     return HttpResponseRedirect('/accounts/login/'
  4.   # ... 
  5.   return render_to_response('template1.html'
  6.  
  7. def my_view2(request): 
  8.   if not request.user.is_authenticated(): 
  9.     return HttpResponseRedirect('/accounts/login/'
  10.   # ... 
  11.   return render_to_response('template2.html'
  12.  
  13. def my_view3(request): 
  14.   if not request.user.is_authenticated(): 
  15.     return HttpResponseRedirect('/accounts/login/'
  16.   # ... 
  17.   return render_to_response('template3.html'
?

這里,每一個視圖開始都檢查request.user是否是已經認證的,是的話,當前用戶已經成功登陸站點否則就重定向/accounts/login/ (注意,雖然我們還沒有講到request.user,但是14章將要講到它.就如你所想像的,request.user描述當前用戶是登陸的還是匿名)

如果我們能夠叢每個視圖里移除那些 重復代,并且只在需要認證的時候指明它們,那就完美了。 我們能夠通過使用一個視圖包裝達到目的。 花點時間來看看這個:
 

  1. def requires_login(view): 
  2.   def new_view(request, *args, **kwargs): 
  3.     if not request.user.is_authenticated(): 
  4.       return HttpResponseRedirect('/accounts/login/'
  5.     return view(request, *args, **kwargs) 
  6.   return new_view 
?

函數requires_login,傳入一個視圖函數view,然后返回一個新的視圖函數new_view.這個新的視圖函數new_view在函數requires_login內定義 處理request.user.is_authenticated()這個驗證,從而決定是否執行原來的view函數

現在,我們可以從views中去掉if not request.user.is_authenticated()驗證.我們可以在URLconf中很容易的用requires_login來包裝實現.
 

  1. from django.conf.urls.defaults import * 
  2. from mysite.views import requires_login, my_view1, my_view2, my_view3 
  3.  
  4. urlpatterns = patterns(''
  5.   (r'^view1/$', requires_login(my_view1)), 
  6.   (r'^view2/$', requires_login(my_view2)), 
  7.   (r'^view3/$', requires_login(my_view3)), 
?

優化后的代碼和前面的功能一樣,但是減少了代碼冗余 現在我們建立了一個漂亮,通用的函數requires_login()來幫助我們修飾所有需要它來驗證的視圖
包含其他URLconf

如果你試圖讓你的代碼用在多個基于Django的站點上,你應該考慮將你的URLconf以包含的方式來處理。

在任何時候,你的URLconf都可以包含其他URLconf模塊。 對于根目錄是基于一系列URL的站點來說,這是必要的。 例如下面的,URLconf包含了其他URLConf:
 

  1. from django.conf.urls.defaults import * 
  2.  
  3. urlpatterns = patterns(''
  4.   (r'^weblog/', include('mysite.blog.urls')), 
  5.   (r'^photos/', include('mysite.photos.urls')), 
  6.   (r'^about/$''mysite.views.about'), 
?

admin模塊有他自己的URLconf,你僅僅只需要在你自己的代碼中加入include就可以了.

這里有個很重要的地方: 例子中的指向 include() 的正則表達式并 不 包含一個 $ (字符串結尾匹配符),但是包含了一個斜桿。 每當Django遇到 include() 時,它將截斷匹配的URL,并把剩余的字符串發往包含的URLconf作進一步處理。

繼續看這個例子,這里就是被包含的URLconf mysite.blog.urls :
 

  1. from django.conf.urls.defaults import * 
  2.  
  3. urlpatterns = patterns(''
  4.   (r'^(/d/d/d/d)/$''mysite.blog.views.year_detail'), 
  5.   (r'^(/d/d/d/d)/(/d/d)/$''mysite.blog.views.month_detail'), 
?

通過這兩個URLconf,下面是一些處理請求的例子:

  •     /weblog/2007/ :在第一個URLconf中,模式 r'^weblog/' 被匹配。 因為它是一個 include() ,Django將截掉所有匹配的文本,在這里是 'weblog/' 。URL剩余的部分是 2007/ , 將在 mysite.blog.urls 這個URLconf的第一行中被匹配到。 URL仍存在的部分為 2007/ ,與第一行的 mysite.blog.urlsURL設置相匹配。
  •     /weblog//2007/(包含兩個斜杠) 在第一個URLconf中,r'^weblog/'匹配 因為它有一個include(),django去掉了匹配的部,在這個例子中匹配的部分是'weblog/' 剩下的部分是/2007/ (最前面有一個斜杠),不匹配mysite.blog.urls中的任何一行.
  •     /about/ : 這個匹配第一個URLconf中的 mysite.views.about 視圖。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东明县| SHOW| 峨山| 临夏县| 亚东县| 尚志市| 本溪市| 新建县| 库车县| 绿春县| 犍为县| 南澳县| 邢台市| 奉节县| 正安县| 安顺市| 临猗县| 乐亭县| 临安市| 静乐县| 通州区| 高尔夫| 松滋市| 密山市| 榆社县| 鄂州市| 油尖旺区| 胶州市| 新建县| 咸阳市| 探索| 太仓市| 湄潭县| 昂仁县| 志丹县| 苍溪县| 金山区| 盐亭县| 隆林| 苏尼特左旗| 新龙县|