Django中間件攔截未登錄url實例詳解
更新時間:2019年09月03日 14:40:22 作者:凌晨4點的太陽
在本篇文章里小編給各位整理了關于Django中間件攔截未登錄url的實例內容以及相關知識點,有需要的朋友們可以學習下。
1.利用裝飾器在視圖中攔截未登錄的url
@login_required(login_url='/user/login/') def homepage(request): pass
這種方法適合于程序中只有少數幾個需要登錄攔截的url。
2. 利用中間件技術攔截未登錄的url
2.1 在settings.py添加MIDDLEWARE設置:middleware.LoginCheckMiddleware
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登錄攔截中間件 'middleware.LoginCheckMiddleware', ]
2.2 在項目目錄下創(chuàng)建middleware.py文件,文件中創(chuàng)建攔截類:LoginCheckMiddleware
import re
from django.http import JsonResponse
from django.shortcuts import HttpResponseRedirect
from django.utils.deprecation import MiddlewareMixin
class LoginCheckMiddleware(MiddlewareMixin):
def process_request(self, request):
# | 分隔要匹配的多個url,從左到右匹配,有匹配就返回匹配值,否則返回None。
pattern = r'^(/$|/user/user/[0-9]+/$|/user/user/$|/user/getuserall|/user/get_token_code|/user/update_phone_no|/stock|/future)'
# 如果 request.path 的開始位置能夠找到這個正則樣式的任意個匹配,就返回一個相應的匹配對象。
# 如果不匹配,就返回None
match = re.search(pattern, request.path)
# 需要攔截的url
if match and not request.user.is_authenticated:
print('用戶未登錄URL攔截 >>: ', request.path)
# 主頁未登錄
if request.path == '/':
return HttpResponseRedirect('/user/login/')
# ajax請求未登錄
else:
return JsonResponse({'status': False, 'info': '用戶未登錄!'})
應用了正則表達式過濾需要攔截的url。
由于ajax請求不能重定向,所以對于ajax請求的url攔截返回json數據,由前端處理返回的結果。
以上就是本次介紹的全部知識點內容,感謝大家的學習和對腳本之家的支持。
相關文章
Numpy中np.random.rand()和np.random.randn() 用法和區(qū)別詳解
這篇文章主要介紹了Numpy中np.random.rand()和np.random.randn() 用法和區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10
Pycharm社區(qū)版創(chuàng)建Flask項目的實現步驟
本文主要介紹了Pycharm社區(qū)版創(chuàng)建Flask項目,包括設置Python環(huán)境、安裝Flask庫以及創(chuàng)建基本的項目結構,具有一定的參考價值,感興趣的可以了解一下2024-06-06

