I我面临着同样的问题,并且像你一样,我想要一个简单的装饰器来包装Django ajax视图,以便像处理其他视图一样处理身份验证。对我来说,看起来很有前途的一种方法是将这样的装饰器与JavaScript结合使用,在响应中寻找特定的值。
这里是第一修订装饰的草案:
from functools import wraps
def ajax_login_required(view_func):
@wraps(view_func)
def wrapper(request, *args, **kwargs):
if request.user.is_authenticated():
return view_func(request, *args, **kwargs)
json = simplejson.dumps({ 'not_authenticated': True })
return HttpResponse(json, mimetype='application/json')
return wrapper
这里是视图:
@ajax_login_required
def ajax_update_module(request, module_slug, action):
# Etc ...
return HttpResponse(json, mimetype='application/json')
这里是JavaScript(jQuery的):
$.post('/restricted-url/', data, function(json) {
if (json.not_authenticated) {
alert('Not authorized.'); // Or something in a message DIV
return;
}
// Etc ...
});
编辑:我试图按照建议使用functools.wraps
。我实际上并没有在工作代码中使用这个装饰器,所以要小心可能的错误。
什么我不知道是怎么从模板的角度确定链接导致的视图是否用@login_required装饰或不... – kender 2008-11-23 22:07:05
该模板没有随机链接。它具有您在模板中专门设计和编码的特定链接。我建议你改变你在模板中专门放置的每个链接。 – 2008-11-23 22:27:21