简体   繁体   English

如何要求登录以访问任何URL Django

[英]How to ask for login to access to any url django

I have thies in views.py 我在views.py中有小偷

 @login_required()
 def dadmin(request):

I had not used @login_required() in dapost and dapage 我没有在dapost和dapage中使用@login_required()

And in url.py 并在url.py中

url(r'^dadmin/$', dadmin, name='dadmin'),
url(r'^dadmin/post/$', dapost, name='dapost'),
url(r'^dadmin/page/$', dapage, name='dapage'),

Now I want is everytime when users try to access domain.com/dadmin/any... it redirect to login page. 现在,我希望每次用户尝试访问domain.com/dadmin/any ...时,它都重定向到登录页面。 how ca i Do that? 我怎么办? without placing @login_required() in dapost and dapage? 没有在dapost和dapage中放置@login_required()?

you can do it by using custom middleware 您可以使用自定义中间件来实现

save this as custom_middleware.py file in your main app 将此文件另存为custom_middleware.py文件

from django.shortcuts import redirect


class CheckUser(object):

    def __init__(self, get_response):

        self.get_response = get_response

    def __call__(self, request):

        if not request.user.is_authenticated() and \
                        request.path.startswith('/dadmin/'):
            return redirect("/login/")

        response = self.get_response(request)


        return response

and in your settings.py edit the middleware 并在您的settings.py编辑middleware

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    #custom middlewares
    'app.custom_middleware.CheckUser'
]

If you set LOGIN_URL in your settings.py: 如果您在settings.py中设置LOGIN_URL:

https://docs.djangoproject.com/en/1.8/ref/settings/#login-url https://docs.djangoproject.com/zh-CN/1.8/ref/settings/#login-url

all anonymous users will be redirected when accessing to urls with login_required() decorator in their views. 使用其视图中的login_required()装饰器访问URL时,将重定向所有匿名用户。

Edit: you can make a custom LoginRequiredMiddleware too, with the path you desire. 编辑:您也可以使用所需的路径制作自定义的LoginRequiredMiddleware。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM