继续上篇关于Django的日志,探索Django的其他方面。
首先想到的是Django里面有没有类似filter的组件。遗憾的是,并未发现Django中有类似过滤器或者拦截器的概念。然而,Django提供了功能或许更为强大(至少是不弱于)这些概念的新东西:middleware。
设想这样的需求:在用户未登录之前,他访问任何页面,都将转入登录页面,要求其登录。这样的判断最适合放在页面逻辑的前端,而不是在页面逻辑中实现。
我们写这样的一个middleware,它拦截所有访问非login页面的请求,检测其cookie,并判断将请求转向login页面或者其请求的页面。
middleware代码如下:
- ''
-
-
-
-
- from django.http import HttpResponseRedirect
- from django.contrib.auth import SESSION_KEY
- from urllib import quote
- class QtsAuthenticationMiddleware(object):
- def process_request(self, request):
-
- 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,才能成功。