Загрязнение параметров HTTP - HTTP parameter pollution

Загрязнение параметров HTTP Короче говоря, HPP - это уязвимость, которая возникает из-за передачи нескольких параметров с одинаковым именем. Здесь нет RFC стандарт того, что следует делать при передаче нескольких параметров. Эта уязвимость была впервые обнаружена в 2009 году.[1] ГЭС можно использовать для поперечного загрязнения каналов, в обход CSRF защита и WAF проверки ввода.[2]

Поведение

Вот как ведет себя серверная часть при передаче нескольких параметров с одинаковым именем

Поведение
ТехнологииРезультат разбораПример
ASP.NET/IISВсе вхождения объединяются запятойпараметр = значение1, значение2
ASP / IISВсе вхождения объединяются запятойпараметр = значение1, значение2
PHP / ApacheТолько последнее появлениеparam = val2
PHP / ЗевсТолько последнее появлениеparam = val2
JSP, сервлет / Apache TomcatТолько первое появлениеparam = val1
JSP, сервлет / сервер приложений OracleТолько первое появлениеparam = val1
JSP, сервлет / пристаньТолько первое появлениеparam = val1
IBM Lotus DominoТолько последнее появлениеparam = val2
IBM HTTP ServerТолько первое появлениеparam = val1
mod_perl, libapreq2 / ApacheТолько первое появлениеparam = val1
Perl CGI / ApacheТолько первое появлениеparam = val1
mod_wsgi (Python) / ApacheТолько первое появлениеparam = val1
Python / ZopeВсе вхождения в списке (массив)param = ['значение1', 'значение2']

[1]

Типы

Сторона клиента

  • Первый порядок / отраженная ГЭС[3]
  • Второй порядок / сохраненная ГЭС[3]
  • Третий порядок / ДОМ ГЭС[3]

На стороне сервера

  • Стандартная ГЭС[3]
  • ГЭС второго порядка[3]

Профилактика

Правильная проверка вводимых данных и осведомленность о веб-технологиях на HPP - это защита от загрязнения параметров HTTP.[4]

Смотрите также

Рекомендации

  1. ^ а б "WSTG - Последнее: Тестирование на предмет загрязнения HTTP-параметров".
  2. ^ "Уязвимости, связанные с загрязнением HTTP-параметров в веб-приложениях" (PDF). 2011.
  3. ^ а б c d е Лука Кареттони и Стефано Ди Паола. «Загрязнение параметров HTTP» (PDF).CS1 maint: использует параметр авторов (связь)
  4. ^ «Как обнаружить атаки, связанные с загрязнением параметров HTTP».