![](/img/trans.png)
[英]How to run a piece of code in a function every 0.2 seconds for 5 seconds?
[英]How to run a piece of code in every view in django?
如果授权失败,我需要在我的一个Django应用程序的每个视图中检查用户授权(我不使用Django内置的auth系统)并将用户重定向到“login please”页面。
代码如下所示:
try:
admin_from_session = request.session['admin'];
admin = Administrator.objects.get(login = admin_from_session.login, password = admin_from_session.password, enabled=True);
except KeyError, Administrator.DoesNotExist:
return HttpResponseRedirect('/controlpanel/login')
问题是: 如何在每个视图的开头运行此代码,而不是每次都重复?
如果我在PHP上编写我的程序,我会将这些代码放在单独的文件中,并在需要授权的每个页面的开头写下这样的代码:
include("redirect_if_not_logged_in.inc.php");
我找到的解决方案是:
这项任务似乎微不足道,但我无法找到解决方案。 我会非常感谢任何帮助。
查看django.contrib.auth装饰器的源代码 。 它们完全符合您的要求,但对于内置的Django身份验证系统( 请参阅文档 )。 为您的身份验证系统做类似的事情应该不难。
顺便说一下,你为什么不使用内置的auth? 您可以将它与自定义身份验证后端一起使用...
我找到了我正在寻找的答案。 函数装饰器允许在函数开头运行代码。
您必须定义装饰器功能
def login_please_decorator(view_func):
"""
Redirect if admin was not logged in
"""
def _decorated(request, *args, **kwargs):
#Check authorization
try:
admin_from_session = request.session['admin'];
admin = Administrator.objects.get(login = admin_from_session.login, password = admin_from_session.password, enabled=True);
return view_func(request,*args, **kwargs);
except KeyError, Administrator.DoesNotExist:
return HttpResponseRedirect('/cp/login?ret=' + request.path);
return _decorated
并使用此函数名称装饰视图:
@login_please_decorator
def some view(request):
# do something ...
# ...
Ludwik Trammer,bugspy.net,谢谢你的帮助。
想到功能装饰器
请查看此处的用户身份验证页面http://docs.djangoproject.com/en/dev/topics/auth/
继续阅读“login_required decorator”。
from django.contrib.auth.decorators import login_required
@login_required
def my_view(request):
...
如果未通过设置“settings.LOGIN_URL”进行身份验证,您可以设置用户重定向的位置。
在页面上还有一个特殊身份验证模板的示例,您可以根据自己喜欢的方式设置样式!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.