Django中對(duì)通過測(cè)試的用戶進(jìn)行限制訪問的方法
限制訪問可以基于某種權(quán)限,某些檢查或者為login視圖提供不同的位置,這些實(shí)現(xiàn)方式大致相同。
一般的方法是直接在視圖的 request.user 上運(yùn)行檢查。 例如,下面視圖確認(rèn)用戶登錄并是否有 polls.can_vote權(quán)限:
def vote(request): if request.user.is_authenticated() and request.user.has_perm('polls.can_vote')): # vote here else: return HttpResponse("You can't vote in this poll.")
并且Django有一個(gè)稱為 user_passes_test 的簡(jiǎn)潔方式。它接受參數(shù)然后為你指定的情況生成裝飾器。
def user_can_vote(user): return user.is_authenticated() and user.has_perm("polls.can_vote") @user_passes_test(user_can_vote, login_url="/login/") def vote(request): # Code here can assume a logged-in user with the correct permission. ...
user_passes_test 使用一個(gè)必需的參數(shù): 一個(gè)可調(diào)用的方法,當(dāng)存在 User 對(duì)象并當(dāng)此用戶允許查看該頁面時(shí)返回 True 。 注意 user_passes_test 不會(huì)自動(dòng)檢查 User
是否認(rèn)證,你應(yīng)該自己做這件事。
例子中我們也展示了第二個(gè)可選的參數(shù) login_url ,它讓你指定你的登錄頁面的URL(默認(rèn)為 /accounts/login/ )。 如果用戶沒有通過測(cè)試,那么user_passes_test將把用戶重定向到login_url
既然檢查用戶是否有一個(gè)特殊權(quán)限是相對(duì)常見的任務(wù),Django為這種情形提供了一個(gè)捷徑: permission_required() 裝飾器。 使用這個(gè)裝飾器,前面的例子可以改寫為:
from django.contrib.auth.decorators import permission_required @permission_required('polls.can_vote', login_url="/login/") def vote(request): # ...
注意, permission_required() 也有一個(gè)可選的 login_url 參數(shù), 這個(gè)參數(shù)默認(rèn)為 '/accounts/login/' 。
限制通用視圖的訪問
在Django用戶郵件列表中問到最多的問題是關(guān)于對(duì)通用視圖的限制性訪問。 為實(shí)現(xiàn)這個(gè)功能,你需要自己包裝視圖,并且在URLconf中,將你自己的版本替換通用視圖:
from django.contrib.auth.decorators import login_required from django.views.generic.date_based import object_detail @login_required def limited_object_detail(*args, **kwargs): return object_detail(*args, **kwargs)
當(dāng)然, 你可以用任何其他限定修飾符來替換 login_required 。
相關(guān)文章
tensorflow查看ckpt各節(jié)點(diǎn)名稱實(shí)例
今天小編就為大家分享一篇tensorflow查看ckpt各節(jié)點(diǎn)名稱實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01解決python執(zhí)行不輸出系統(tǒng)命令彈框的問題
今天小編就為大家分享一篇解決python執(zhí)行不輸出系統(tǒng)命令彈框的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-06-06Python日期格式和字符串格式相互轉(zhuǎn)換的方法
這篇文章主要介紹了Python日期格式和字符串格式相互轉(zhuǎn)換的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02python3學(xué)習(xí)之Splash的安裝與實(shí)例教程
splash 是一個(gè)python語言編寫的用于配合scrapy解析js的庫,下面這篇文章主要給大家介紹了關(guān)于python3學(xué)習(xí)之Splash的安裝與使用的一些相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07用Python監(jiān)控你的朋友都在瀏覽哪些網(wǎng)站?
今天教各位小伙伴一個(gè)黑科技,用Python監(jiān)控你的朋友都在瀏覽哪些網(wǎng)站,文中有非常詳細(xì)的介紹,對(duì)正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下2021-05-05Dockerfile構(gòu)建一個(gè)Python Flask 鏡像
這篇文章主要介紹了Dockerfile構(gòu)建一個(gè)Python Flask 鏡像,對(duì)正在學(xué)習(xí)的你有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-01-01