Nginx 文件名逻辑漏洞(CVE-2013-4547)

AffettoIris 2023-9-24 9,091,070 9/24

官网给的漏洞原理及题解

题解

vlhub给了我们这样的网页

Nginx 文件名逻辑漏洞(CVE-2013-4547)

测试发现只不能提交.php文件,我们将一句话木马<?php phpinfo(); ?>写进1.txt,重命名为1.jpg,然后上传,这个过程burp抓包,将filename从"1.jpg"改为"1.jpg "并forward,上传成功~服务器存着一个叫"1.jpg "的非图片文件.

Nginx 文件名逻辑漏洞(CVE-2013-4547)

在浏览器输入62.234.14.252:8080/uploadfiles/1.jpgaa.php并抓包,

Nginx 文件名逻辑漏洞(CVE-2013-4547)

然后Forward,漏洞利用成功:

Nginx 文件名逻辑漏洞(CVE-2013-4547)

我的服务器是nginx1.20,比较新,上述漏洞未能成功显示phpinfo();显示如下:

Nginx 文件名逻辑漏洞(CVE-2013-4547)

踩坑点及深入挖掘原理

  1. 成功上传1.jpg[0x20]后,访问http://62.234.14.252:8080/uploadfiles/1.jpg显示如下

    Nginx 文件名逻辑漏洞(CVE-2013-4547)

    因为服务器上存的是1.jpg[0x20],而浏览器输入62.234.14.252:8080/uploadfiles/1.jpg[0x20]实际访问的还是62.234.14.252:8080/uploadfiles/1.jpg (对,浏览器会过滤忽略掉url开头结尾的空格),所以404了。

  2. 假设我们上传的就是1.jpg,文件名不带空格,然后我们访问62.234.14.252:8080/uploadfiles/1.jpg,这个访问过程无法被FoxyProxy和burp抓包,可能是因为纯图片不是报文不在其业务范围的缘故。

    解决如何即访问1.jpg[0x20]又能让burp抓到包?:

    访问http://62.234.14.252:8080/uploadfiles/1.jpgaa.php,违背了纯图片就能被抓包了。然后用burp在底层将aa修改为[0x20][0x00]就能访问1.jpg[0x20]了

  3. 官方教程教收尾阶段访问http://your-ip:8080/uploadfiles/1.jpg[0x20][0x00].php,我傻乎乎的尝试在浏览器输入带[]的、不带[]的、[0x20]改写而成空格的、[0x00]改写不成空,都显示404了。后来才知道要去burp去修改报文的十六进制底层,即访问http://62.234.14.252:8080/uploadfiles/1.jpgaa.php,其中aa是可以留的占位符,a在底层对应ascii的十六进制61,将[61][61]改成[20][00],其中20是空格,00是空的ascii。

  4. 这里应该是用到了0x00截断原理了,具体原理是 系统在对文件名的读取时,如果遇到0x00,就会认为读取已结束。这个常用在对文件类型名的绕过上。还不止这个原理。

  5. 当Nginx得到一个用户请求时,首先对url进行解析,进行正则匹配,如果匹配到以.php后缀结尾的文件名(即http://62.234.14.252:8080/uploadfiles/1.jpg \0.php),会将请求的PHP文件交给PHP-CGI去解析。其中处理模块如下:

    location ~ \.php$ {
        root           html;
        include        fastcgi_params;
    
        fastcgi_pass   IP:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /var/www/html$fastcgi_script_name;
        fastcgi_param  DOCUMENT_ROOT /var/www/html;
    }

    以.php结尾的文件都会交给该模块处理,其中fastcgi_pass就是Nginx与PHP-FPM之间的媒介,通过ip+port的方式将请求转发给PHP解释器。

    但是我们有代码的文件它叫’1.jpg ‘啊,不叫'1.php'不叫'1.jpg php'不叫'1.jpgphp',所以我们利用0x00的阶段原理,用0x00将'1.jpg '和.php分隔开。http://62.234.14.252:8080/uploadfiles/1.jpg \0.php通过.php进入这个Location块;但进入后,Nginx却因0x00隔断而错误地认为请求的文件是1.gif[0x20],就将'1.gif '交付PHP-CGI去解析(就设置其为SCRIPT_FILENAME的值发送给fastcgi)。

- THE END -

AffettoIris

10月16日15:24

最后修改:2023年10月16日
2

共有 141,472 条评论

  1. ThunderKickV9Guaps

    Amo a energia de BETesporte Casino, oferece um prazer esportivo intenso. As opcoes sao amplas como um campo de futebol, com sessoes ao vivo cheias de energia. Eleva a experiencia de jogo. Os agentes respondem com rapidez, sempre pronto para entrar em campo. Os ganhos chegam sem atraso, embora recompensas extras seriam um hat-trick. Em sintese, BETesporte Casino vale uma aposta certa para entusiastas de jogos modernos ! Vale destacar o design e moderno e vibrante, tornando cada sessao mais competitiva. Igualmente impressionante as opcoes variadas de apostas esportivas, fortalece o senso de comunidade.
    <a href=https://betesporte365.app/>Navegar no site</a>|

  2. Jasondoche

    1xBet код для регистрации на приветственный бонус в 2026 — введите промокод и активируйте предложение в размере 100% до 100$. Данный бонусный код предоставляет шанс активировать акционный бонус от компании 1xBet после создания аккаунта.Актуальный промокод доступен на сайте 1xBet — <a href=https://efaflex.ru/include/pages/?promokod_pri_registracii_6.html>https://efaflex.ru/include/pages/?promokod_pri_registracii_6.html</a&gt;.

  3. Kennyevats

    Продвижение сайта помогает компаниям привлекать заинтересованную аудиторию и повышать конверсию. Оптимизация включает работу с контентом, структурой и техническими аспектами ресурса. Регулярная аналитика и корректировка стратегии позволяют поддерживать стабильный рост. В результате сайт становится удобным и надёжным для пользователей. Подробнее по ссылке <a href=https://qa.andytoan.vn/index.php?qa=242151&qa_1=%D0%BF%D0%BE%D1%87%D0%B5%D0%BC%D1%83-seo-%D0%BB%D1%83%D1%87%D1%88%D0%B8%D0%B9-%D1%81%D0%BF%D0%BE%D1%81%D0%BE%D0%B1-%D0%BF%D1%80%D0%B8%D0%B2%D0%BB%D0%B5%D1%87%D1%8C-%D0%BA%D0%BB%D0%B8%D0%B5%D0%BD%D1%82%D0%BE%D0%B2>https://qa.andytoan.vn/index.php?qa=242151&qa_1=почему-seo-лучший-способ-привлечь-клиентов</a&gt;

  4. StanleyNix

    Бесплатные промокоды на 2026 от букмекерской конторы 1xBet: при регистрации, на бесплатную ставку. Рассказываем, как использовать и куда вводить промокоды в 1хБет. <a href=https://ecoinn74.ru/images/pgs/1xbet_promokod_pri_registracii_bonus.html >промокод на фрибет в 1хбет</a>. Бесплатный промокод для увеличения бонуса. Букмекерская контора 1хБет – одна из самых популярных беттинговых площадок, предлагающая высокие коэффициенты, широкую линию с дополнительной росписью. Благодаря низкой марже БК пользователи стабильно зарабатывают на ставках на спорт. Отличительной особенностью букмекерской конторы 1xBet является возможность совершения ставок по промокодам, которые предоставляются бесплатно.

  5. JamesNat

    <a href=https://t.me/ttanmod>скачать тик ток мод с модом</a> Telegram – Центр Распространения Модификаций: Осторожность и Выбор Надежного Источника Запросы "скачать тик ток мод телеграм" и "скачать тик ток мод 2025 тг" указывают на Telegram как на популярную платформу для поиска и загрузки модов. Однако приоритетом является безопасность: выбирайте проверенные каналы и группы, чтобы избежать установки вредоносного ПО. Определитесь с желаемым функционалом: отключение рекламы, расширенные инструменты редактирования, возможность загрузки видео без водяного знака или снятие региональных ограничений.

  6. Kennyevats

    SEO-продвижение делает сайт заметным и эффективным инструментом для бизнеса. Работа с контентом, структурой страниц и техническими параметрами помогает улучшить позиции и повысить конверсию. Регулярная аналитика и корректировка стратегии обеспечивают стабильный рост. Такой подход делает сайт надёжным источником клиентов и способствует развитию компании. Читайте подробнее <a href=https://gummipuppen-wiki.de/index.php?title=%D0%A1%D0%B5%D0%BE_%D0%9F%D1%80%D0%BE%D0%B4%D0%B2%D0%B8%D0%B6%D0%B5%D0%BD%D0%B8%D0%B5_%D0%A1%D0%B0%D0%B9%D1%82%D0%BE%D0%B2_%D0%94%D0%BB%D1%8F_%D0%98%D0%BD%D1%82%D0%B5%D1%80%D0%BD%D0%B5%D1%82_%D0%9C%D0%B0%D0%B3%D0%B0%D0%B7%D0%B8%D0%BD%D0%BE%D0%B2>https://gummipuppen-wiki.de/index.php?title=Сео_Продвижение_Сайтов_Для_Интернет_Магазинов</a&gt;

  7. Bobbyglige

    Мастерица с потрясающей улыбкой и грациозной фигурой делает массаж незабываемым. Каждое движение мягкое, плавное и чувственное, ощущаешь заботу и внимание. Атмосфера салона располагает к полному релаксу. Очень советую, эротический массаж цена Новосиб – <a href=https://sibirka.com/>https://sibirka.com/</a&gt;. Всё просто шикарно, обязательно вернусь.

  8. Johnnyboync

    TikTok Mod: Эволюция Мобильного Творчества в 2025 Году В стремительно меняющемся цифровом ландшафте 2025 года TikTok, как платформа коротких видео, продолжает захватывать внимание миллионов. Однако стремление к большей персонализации и расширенным функциям привело к появлению так называемых "TikTok модов" – модифицированных версий приложения, предлагающих уникальные возможности. Ключевым запросом при этом остается "тик ток мод скачать 2025 без вирусов", что подчеркивает важность безопасности в мире цифровых модификаций. Пользователи стремятся получить максимум от платформы, не подвергая свои устройства риску. <a href=https://t.me/ttanmod>скачать мод тик ток русская версия</a>

  9. MarvinDef

    Le code promo est supprime : entrez-le dans le champ « Code promo » et reclamez un bonus de bienvenue de 100% jusqua 130€, pour vos paris sportifs. Inscrivez-vous sur 1xBet ou via lapplication mobile. Apres votre premier depot, vous activerez le code bonus. Loffre est valable pour toute lannee 2026, et le bonus doit etre mise dans les 30 jours. Decouvrez plus dinformations sur le code promo via ce lien — <a href=https://www.lamarinda.it/wp-content/pgs/tufli_oseny_2015.html>https://www.lamarinda.it/wp-content/pgs/tufli_oseny_2015.html</a&gt;.

  10. JamesTrede

    <a href=https://pushnews.com.ua/tsikavi-fakty-pro-radio-istoriia-evoliutsiia-ta-suchasnist/>про радіо</a>