本文介绍了Django将所有未经身份验证的用户重定向到登录页面的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个django网站,许多网址和意见。现在我要求将所有未经身份验证的用户重定向到某个着陆页。因此,所有视图都必须检查 user.is_authenticated()
并返回一组新的着陆页。 可以以一种很好的方式完成,而不是弄乱我的 views.py
/ urls.py
这么多?
解决方案
您可以使用中间件。
这样的事情将会检查每个请求的用户身份:
class AuthRequiredMiddleware(object):
def process_request(self,request):
如果没有request.user.is_authenticated():
返回HttpResponseRedirect(reverse('landing_page'))#或http回复
返回无
文档:
此外,忘记在settings.py中启用它
MIDDLEWARE_CLASSES =(
...
'path。 to.your.AuthRequiredMiddleware',
)
I have a django website with many urls and views. Now I have asked to redirect all non-authenticated users to a certain landing page. So, all views must check if user.is_authenticated()
and return to a new set of landing pages.
Can it be done in a pretty way, instead of messing with my views.py
/urls.py
that much?
解决方案
You can use Middleware.
Something like this will check user auth every request:
class AuthRequiredMiddleware(object):
def process_request(self, request):
if not request.user.is_authenticated():
return HttpResponseRedirect(reverse('landing_page')) # or http response
return None
Docs: process_request
Also, don't forget to enable it in settings.py
MIDDLEWARE_CLASSES = (
...
'path.to.your.AuthRequiredMiddleware',
)
这篇关于Django将所有未经身份验证的用户重定向到登录页面的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!