zoukankan      html  css  js  c++  java
  • Apache HTTPD 多后缀解析漏洞

    Apache HTTPD 多后缀解析漏洞

    Apache HTTPD 支持一个文件拥有多个后缀,并为不同后缀执行不同的指令。比如,如下配置文件:

    AddType text/html .html
    AddLanguage zh-CN .cn

    其给.html后缀增加了media-type,值为text/html;给.cn后缀增加了语言,值为zh-CN。此时,如果用户请求文件index.cn.html,他将返回一个中文的html页面。

    以上就是Apache多后缀的特性。如果运维人员给.php后缀增加了处理器:

    AddHandler application/x-httpd-php .php

    那么,在有多个后缀的情况下,只要一个文件含有.php后缀的文件即将被识别成PHP文件,没必要是最后一个后缀。利用这个特性,将会造成一个可以绕过上传白名单的解析漏洞。

    漏洞环境

    运行如下命令启动一个稳定版Apache,并附带PHP 7.3环境:

    docker-compose up -d

    漏洞复现

    环境运行后,访问http://your-ip/uploadfiles/apache.php.jpeg即可发现,phpinfo被执行了,该文件被解析为php脚本。

    http://your-ip/index.php中是一个白名单检查文件后缀的上传组件,上传完成后并未重命名。我们可以通过上传文件名为xxx.php.jpgxxx.php.jpeg的文件,利用Apache解析漏洞进行getshell。



     

    参考:

    https://vulhub.org/#/environments/httpd/apache_parsing_vulnerability/

    二、漏洞环境
    路径:vulhub/httpd/apache_parsing_vulnerability
    启动一个稳定版Apache,并附带PHP 7.3环境:docker-compose up -d

    然后访问:http://localhost

    本地文件上传,文件内容:

    <?php phpinfo(); ?>
    

    上传成功以后,访问如下地址即可看到效果了:


    http://localhost/uploadfiles/test.php.jpg

  • 相关阅读:
    2016个人测试1(待续。。。)
    bzoj2548[Cstc2002]灭鼠行动
    noip2013 积木大赛
    noip2013 火柴排队
    Noip2000 T3 单词接龙
    noip2017爆炸记——题解&总结&反省(普及组+提高组)
    【2017.10.26-】后缀数组学习笔记
    20171002清北
    【搜索党】卡时技巧
    【noip】noip201503求和(题解可能不完美,但绝对详细)
  • 原文地址:https://www.cnblogs.com/bonelee/p/14727989.html
Copyright © 2011-2022 走看看