Я работаю над Middleware в версии 2.1 django. Это LoginMiddleWare, где мне нужно исключить некоторые URL-адреса, если requested url exits возвращает None
ниже часть кода промежуточного программного обеспечения: middleware.py
def process_view(self, request, view_func, view_args, view_kwargs):
exclude_urls = [r'[admin]', r'[login]', r'[register]', r'[demo]']
if (request.path_info in exclude_urls):
print('BELOW IS EXCLUDED URL')
print(request.path_info)
return None
else:
print('BELOW IS NOT EXCLUDED URL')
print(request.path_info)
Приведенный выше код должен идентифицировать URL-адрес, запрошенный пользователем request.path_info, и должен проверять выходы в exclude_urls.
ПРИМЕР: если запрошенный URL-адрес - https://www.example.com/login?query=1, он должен идентифицировать login в этом конкретном URL-адресе и должен возвращать None
После просмотра моего кода ниже пришло решение
url_list = [
'admin/login',
'/demo/login'
]
requested_path = request.path_info
print('requested path :'+requested_path)
for i in url_list:
r1 = re.findall(r'^'+requested_path, i)
print(len(r1))
if len(r1) > 0:
return None
else:
if not request.session.get('user_logged', None):
print("Session Empty")
return redirect('login') //HERE USER IS GOING INTO CONTINUOUS REDIRECT LOOP HOW CAN I STOP INFINITE REDIRECTS
else:
print("Session Exits")
ВЫШЕ ИЗМЕНЕНИЯ В КОДЕ РАБОТАЮТ НА НЕКОТОРЫХ РАСШИРЕНИЯХ страницы NOW THE ISSUE IS IT REDIRECTING TO https://www.example.com/demo/login снова и снова, как я могу это остановить.
Чего я хочу достичь
admin/login and demo/login в настоящее время - это два URL-адреса, которые мне нужно исключить при проверке наличия session exits in middleware.py.
ДЕЛО 1 :
ЕСЛИ URL-адрес СУЩЕСТВУЕТ В СПИСКЕ И СЕССИЯ ПУСТО И У ПОЛЬЗОВАТЕЛЯ ИМЕЕТ URL-адрес REQUESTED demo/login, мне нужно, чтобы он перенаправил его на свой URL-адрес demo/login URL
СЛУЧАЙ 2:
ЕСЛИ ЗАПРОС ПОЛЬЗОВАТЕЛЕМ УКАЗАН НЕ УКАЗАННЫЙ В list url_list URL. В ЭТОМ ЭТОМ Я ПРОВЕРЯЮ, ПУСТО ЛИ СЕССИЯ, ТОГДА Я ПЕРЕНАПРАВЛЯЮ ПОЛЬЗОВАТЕЛЯ НА страницу demo/login [## НО ПОЛЬЗОВАТЕЛЬ переходит к НЕПРЕРЫВНОМУ ПОВТОРНОМУ ЦИКЛУ. КАК Я МОГУ ОСТАНОВИТЬ БЕСКОНЕЧНЫЕ ПОВТОРНЫЕ НАПРАВЛЕНИЯ ##]
@ Иван Старостин спасибо за ответ. Я отредактировал свой вопрос ниже. пожалуйста, сделайте необходимое.
return redirect('login')?
Что вы пытаетесь достичь? Запретить анонимный доступ ко всем страницам, кроме login / register?
@Ivan Starostin, ЧТОБЫ УЗНАТЬ ВОПРОС, Я ДОБАВИЛ БОЛЬШЕ ДЕТАЛЕЙ ОТНОСИТЕЛЬНО ДОСТИЖЕНИЙ. ПОЖАЛУЙСТА НА НЕОБХОДИМОЕ.
Caps не проясняет смутные мысли.
@IvanStarostin хорошо сказано :)






Предполагая, что вы используете именованные URL, вы можете использовать его так:
url_list = [
'admin:login',
'demo:login'
]
curl = request.resolver_match.view_name
if curl in url_list:
if request.session.get('user_logged'):
return redirect('/already-logged-in') # make a new url for this
else:
if not request.session.get('user_logged'):
return redirect('/login')
ОТВЕТ НЕМНОГО ОТЛИЧАЕТСЯ. Я ИЩУ ДРУГОЕ РЕШЕНИЕ, ЧТОБЫ УЧИТАТЬ ВОПРОС. Я ДОБАВИЛ БОЛЬШЕ ДЕТАЛЕЙ ОТНОСИТЕЛЬНО ДОСТИЖЕНИЙ. ПОЖАЛУЙСТА НА НЕОБХОДИМОЕ.
В первом случае вам нужно остановить перенаправление, потому что пользователя уже запросили для входа в систему. Это должно остановить ваш бесконечный цикл перенаправления
@PavanWebbeez см. Обновленный ответ. И не используйте Caps Lock, это нечитаемо.
К сожалению, результат не изменился.
Здесь нет регулярного выражения. Квадратные скобки в регулярном выражении (если оно было) означают «список символов». Таким образом, код r '[admin]' будет соответствовать
a,d,m,iилиn(len = 1). Удалите все попытки "регулярного выражения", возьмите подстроку того, с чего начинается URL, и сравните с простым списком для включения (что вы уже сделали).