继续上篇关于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,才能成功。