12-%00截断(Get型)

12-%00截断(Get型)

%00​截断利用的是PHP旧版本在处理文件名时的一个漏洞,可以欺骗服务器,将本不允许上传的*.php​文件保存为合法的*.jpg文件,从而获得WebShell。

📝 漏洞原理:都是 null 字符惹的祸

这个漏洞的核心是ASCII码值为0的null​字符(%00​或0x00​)。在C语言等底层语言中,这个字符被当作字符串的​结束标志

PHP的部分文件处理函数(如move_uploaded_file()​)底层是用C语言实现的。当它们在构造文件路径时,一旦遇到0x00​,就会认为字符串到此结束,并​无情地丢弃其后的所有内容。攻击者正是利用这一点,让服务器在保存文件时"断章取义"。

🔎 源码分析:漏洞是如何产生的

第十二关的源码是理解问题的关键:

复制代码
$img_path = $_POST['save_path']."/".rand(10, 99).date("YmdHis").".".$file_ext;

源码中的关键点如下:

  • 白名单验证 :程序会检查上传文件的后缀名(如.jpg, .png, .gif)是否在白名单内。
  • 路径可控 :文件最终保存的路径$img_path中, $_POST['save_path']部分完全由用户通过POST请求控制
  • 拼接缺陷 :程序直接将用户可控的$_POST['save_path']与服务器生成的文件名进行了拼接。

因此,攻击的核心思路就是:控制$_POST['save_path']​参数,在其中注入null​字符,从而"截断"掉后面服务器自动添加的、合法的.jpg后缀。

🛡️ 利用条件:复现漏洞的前提

要成功复现此漏洞,需要满足以下两个关键条件,这也是在实际渗透测试中判断是否存在此漏洞的重要依据:

  1. PHP版本低于5.3.4:该漏洞在高版本中已被修复。
  2. magic_quotes_gpc 配置为 Off :若此选项开启,会转义%00这类特殊字符,导致注入失败。
  3. (补充)取决于底层函数实现:此漏洞并非所有PHP文件操作函数都存在,关键在于该函数是否基于C语言的字符串处理逻辑。

相关推荐
大方子1 小时前
【好靶场】PDF也可以有XSS1
网络安全·好靶场
学逆向的3 小时前
C++模板
开发语言·c++·网络安全
2601_955505254 小时前
自然人身份确权可信基础设施赋能身份风险等级标签合规
人工智能·网络安全·金融·健康医疗·媒体·教育电商·政务
百度安全5 小时前
2025 百度 ESG 报告发布:以 AI 筑盾,共建可信数字生态
人工智能·网络安全
云安全助手6 小时前
国内调用GPT的现实困境与聚合平台解决方案探析
网络·人工智能·网络安全·ai大模型
持敬chijing21 小时前
Web渗透之前后端漏洞-文件包含漏洞
前端·安全·web安全·网络安全·网络攻击模型·安全威胁分析
lcreek1 天前
SQL 注入漏洞详解:从原理到防御的完整学习指南
网络安全·sql注入
持敬chijing1 天前
Web渗透之前后端漏洞-文件上传漏洞-过滤绕过与配置文件漏洞-条件竞争漏洞
前端·安全·web安全·网络安全·网络攻击模型·安全威胁分析
txg6661 天前
MirrorFuzz:利用共享漏洞与大模型的深度学习框架 API 模糊测试
人工智能·深度学习·安全·网络安全
是逍遥子没错1 天前
昆仑AI SRC赏金猎人实战手册
web安全·网络安全·系统安全·oa系统·src挖掘