码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • CVE-2017-15715 apache换行解析&文件上传漏洞


    影响范围

    httpd 2.4.0~2.4.29

    复现环境

    vulhub/httpd/CVE-2017-15715
    docker-compose

    漏洞原理

    在apache2的配置文件:
    /etc/apache2/conf-available/docker-php.conf
    中,php的文件匹配以正则形式表达
    在这里插入图片描述

    ".php$"的正则匹配模式意味着以.php结尾的文件名会被解析为php
    但是对于字符串来说“结尾”有可能以换行作为结束
    在这里插入图片描述如图所示,.php与.php\n均可匹配上
    因此在文件上传时将php后添加\n即可
    \n的ascii为10,转换为16进制为0A,构造.php[0A]16即可完成攻击

    漏洞复现

    在vulhub的CVE-2017-15715下

    docker-compose build
    docker-compose up -d
    
    • 1
    • 2

    访问ip:8080即可进入页面
    在这里插入图片描述
    选择php一句话木马进行上传,并使用burp抓包
    在文件名后敲一个空格,之后双击空格在右侧的十六进制处填写0A进行应用
    在这里插入图片描述
    访问8080/test.php%0A即可执行payload在这里插入图片描述

    修复意见

    虽然源码中已经在后端做了检查,但仍应先过滤文件名的一些特殊字符再做检查
    在这里插入图片描述

  • 相关阅读:
    修改pg 连接数 --chatGPT
    【MySQL】范式
    批量循环查询
    [go学习笔记.第十六章.TCP编程] 3.项目-海量用户即时通讯系统-redis介入,用户登录,注册
    2023-09-27 LeetCode每日一题(餐厅过滤器)
    Kotlin 中如何使用 Fuel 库进行代理切换?
    探索Facebook的创新实验室:社交媒体的研发之旅
    单调栈——包含min函数的栈
    【MySQL数据库重点】第二节:MySQL基础知识(基本操作)
    word交叉引用的使用
  • 原文地址:https://blog.csdn.net/mirocky/article/details/133810342
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号