Каковы проблемы безопасности при перенаправлении пользователя после входа на URL, указанный в форме входа? - PullRequest
5 голосов
/ 08 июня 2011

У меня есть личная зона на моем сайте, где, если пользователь не вошел в систему, он перенаправляется на URL входа с помощью? Redirect = [CURRENT_URL] и перенаправляется обратно на [CURRENT_URL] после успешного входа в систему.

Каковы потенциальные проблемы безопасности при таком подходе, как их предотвратить и каковы альтернативы?

например. злоумышленник может перейти на мой сайт с помощью перенаправленной ссылки на другой сайт, сможет ли этот сайт украсть файл cookie для входа в систему моего пользователя? Можно ли запустить произвольный JavaScript на моем сайте с таким подходом?

1 Ответ

2 голосов
/ 08 июня 2011

Если текущий URL не отредактирован, вы можете быть предметом

  • XSS (кража печенья, инъекция сценарии)
  • Разделение заголовка ответа

и т.д.

Если вы знаете, что текущий URL-адрес является константой и не имеет параметров, это не так рискованно. Как только вы добавляете параметры или создаете URL-адрес на основе пользовательского ввода, возникает хитрость.

Тривиальный пример XSS:

Допустим, в вашем URL-адресе может быть введена строка запроса с помощью пользовательского ввода. затем что мешает им сказать

redirectUrl = "yoursite.jsp somevariable =?" Предупреждение ( 'вредоносных') "); или же redirectUrl = "yoursite.jsp somevariable =" тревога (document.cookies) ");

И кража ваших куки или выполнение другого злого сценария Java.

Расщепление ответов сложнее. По сути, если вы можете вводить CRLF, вы можете делать очень странные вещи.

Википедия имеет приличное объяснение этой уязвимости - есть и другие, которые вы можете найти, прибегнув к поиску ответов http.

Я пропустил наиболее очевидную атаку, которая заключается в том, что если пользователь может контролировать URL-адрес, по которому он может перейти на сайт, похожий на ваш, и убедить пользователя ввести кредитные карты, учетные данные и т. Д. Например, если вы являетесь банком, и кто-то может ввести

redirectURL = "http://myfakebank.com"

и копирует вашу страницу, черт возьми, пользователь с радостью скажет: «Конечно, я снова введу свои учетные данные»

...