`

Django中间件

阅读更多

继续上篇关于Django的日志,探索Django的其他方面。

首先想到的是Django里面有没有类似filter的组件。遗憾的是,并未发现Django中有类似过滤器或者拦截器的概念。然而,Django提供了功能或许更为强大(至少是不弱于)这些概念的新东西:middleware

设想这样的需求:在用户未登录之前,他访问任何页面,都将转入登录页面,要求其登录。这样的判断最适合放在页面逻辑的前端,而不是在页面逻辑中实现。

我们写这样的一个middleware,它拦截所有访问非login页面的请求,检测其cookie,并判断将请求转向login页面或者其请求的页面。

middleware代码如下:

 

'''
Created on 2009-4-9

@author: Administrator
'''
from django.http import HttpResponseRedirect 
from django.contrib.auth import SESSION_KEY 
from urllib import quote 
class QtsAuthenticationMiddleware(object): 
    def process_request(self, request):
        #print request.path 
        if request.path != '/login/': 
            if "favorite_color1" in request.COOKIES:
                pass
            else:
                return HttpResponseRedirect("http://lqqm.net")

 

 

 

settings.py中配置此middleware

 

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'middleware.QtsAuthenticationMiddleware',
)

 

 

 

当用户第一次请求musician_list,会转向两全其美。

只有用户访问过login,设置了cookie,再访问musician_list,才能成功。

  • src.rar (3.7 KB)
  • 下载次数: 76
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics