• 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

  • 相关阅读:
    最好的委托与事件详解一(转自张子阳博客)
    事务处理两种方式(转自一壶茶水)
    条目列表点击效果
    html可变大小字体
    udp群聊
    vbs隐藏运行bat之木马合体
    淘宝客网站的链接跳转形式
    工作之外八小时,用辛苦换幸福
    怕吃苦,吃苦一辈子
    外链建设的六个方法
  • 原文地址:https://www.cnblogs.com/bonelee/p/14727989.html
Copyright © 2020-2023  润新知