欢迎来到[自学php网] ①群 AG亚游集团

AG亚游集团 > 网站后台 > 网站安全 >

DEDECMS全局变量覆盖漏洞科普

来源:自学PHP网 ?? 时间:2018-11-07 14:20?作者:

[导读] DEDECMS全局变量覆盖漏洞最早是狼族安全小组09年公布的,官方硬撑到现在没修补漏洞,到现在基本上覆盖了DEDECMS全部的版本。个人猜想是不是官方故意留下的后门。下面稍微科普下这个...

DEDECMS全局变量覆盖漏洞最早是狼族安全小组09年公布的,官方硬撑到现在没修补漏洞,到现在基本上覆盖了DEDECMS全部的版本。个人猜想是不是官方故意留下的后门。下面稍微科普下这个漏洞,大牛们可以完全无视:

 

一. 了解PHP超级全局变量

下面是PHP的超级全局变量,可以了解一个特性,全是数组。

$GLOBALS, 所有全局变量数组
$_SERVER, 服务器环境变量数组
$_GET,通过GET方法传递给脚本的变量数组
$_POST, 通过POST方法传递给脚本的变量数组
$_COOKIE,cookie变量数组
$_REQUEST,所有用户输入的变量数组,包括$_GET, $_POST和$_COOKIE所包含的输入内容
$_FILES,与文件上传相关得变量数组
$_ENV,环境变量数组
$_SESSION,会话变量数组

 

二. 理解$_GET变量

 

可以写个PHP来看看:

<?phpvar_dump($_GET);?>

 

访问

/wwwaff42ctoaff4com /test.php?key=value
得到

array(1) { ["key"]=> string(5) "value" }

OK,看到这里应该明白了,$_GET就是个数组,我们用GET方法可以传一个数组。

 

再访问

/wwwaff42ctoaff4com /test.php?key[arr1]=value

得到

array(1) { ["key"]=> array(1) { ["arr1"]=> string(5) "value" } }

我们通过GET方法传入了一个嵌套数组。

 

到这里其实问题就出来了,很多PHP安全资料都没提过GET传嵌套数组的这个特性,偶尔在几个exploit里看到 - -!

 

三. 深入跟进DEDECMS全局变量注册漏洞

 

真正理解了$_GET变量后,我们来深入跟进这个漏洞产生的真正原因,模拟一下漏洞的全过程:

 

提交一个嵌套数组:

/wwwaff42ctoaff4com /test.php?_POST[GLOBALS][cfg_dbname]=X

 

array(1) { ["_POST"]=> array(1) { ["GLOBALS"]=> array(1) { ["cfg_dbname"]=> string(1) "X" } } }

 

 

假如数据传入了DEDECMS程序,在第一层过滤,DEDECMS会检查$_REQUEST里有没有全局变量的关键字,但我们的KEY是_POST且是个数组,所以轻松绕过。

foreach($_REQUEST as $_k=>$_v)
{
 if( strlen($_k)>0 && eregi('^(cfg_|GLOBALS)',$_k) )
 {
        exit('Request var not allow!');
 }
}

 

接着进入真正的注册变量流程,按顺序是先从$_GET变量注册的,我们的KEY是(_POST),第一轮遍历$_GET成功注册了变量$_POST,第二轮遍历$_POST成功注册了变量$GLOBALS !

foreach(Array('_GET','_POST','_COOKIE') as $_request)
{
 foreach($$_request as $_k => $_v) ${$_k} = _RunMagicQuotes($_v);
}

 

到这里漏洞的原因就清楚了,程序通过$_GET注册了$_POST,通过$_POST注册了$GLOBALS!

 

 

四. 领悟漏洞后的修补

 

完全领悟这个漏洞后,就会知道怎么修补了。 

 

1. 可以看看DISCUZ是怎么做的,当发现KEY的第一个字符存在_就不注册变量。

 

foreach(
array('_COOKIE', '_POST', '_GET') as $_request) { 
foreach($$_request as $_key => $_value) {  
$_key{0} != '_' && $$_key = daddslashes($_value); 
}}

2. DEDECMS可以用下面的方法临时修补,当遍历$_POST注册变量,发现变量名存在GLOBALS就会阻止注册变量。

foreach(Array('_GET','_POST','_COOKIE') as $_request)
{
         foreach($$_request as $_k => $_v) {
                    if( strlen($_k)>0 && eregi('^(cfg_|GLOBALS)',$_k) ){
                            exit('Request var not allow!');
                   }
                    ${$_k} = _RunMagicQuotes($_v);
    }
}

 

PS:安全就是基础,必须理解好基础。

最新文章

点击排行

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号@版权所有AG亚游集团

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

这次来华学习改革开放经验的是朝所有道 市委员长 暴风来白烟起雨突袭 尉犁县棉花“伤心欲绝” 数据揭示恒大吸粉强超巴萨皇马 30+球迷最支持申花 公司偷排“毒液”垃圾场讨6000余万元处理费 人大代表:“神医神药”蒙骗老人 医疗诈骗待整治 你关心的国计民生热点话题 这里有最权威回复 以色列官员:以许诺帮首批10国将使馆搬至耶路撒冷 汤尤杯小组赛也有看点!张军为何给弟子打“及格”? 台民调:蔡当局不满意度达64% 民众“一面倒”不满 人民日报海外版:优质内容将成短视频平台制胜绝招 贵人资本梁渊:港股近期走势先升后随A股 留意绩优股 中国制造的这个“巨无霸”将出口 终结欧美垄断
人物|专访深圳人人雷曼主帅张军:为深圳情怀而奋斗 联赛第11球!上港核武复苏 赛前看自己集锦还真有用 叙媒:以色列向叙首都射导弹 叙两处军事设施被袭 8名印度男子轮奸怀孕山羊致其死亡 又刷新了认知 德国纪录片反思中国留学生遇害案 质疑警方正义性 奥古斯托:阵型调整后变更好 韦世豪有世界级水平 史上最严校外培训整顿 让3500名万学员公司股价跌 交互地图展现全球城市化进程 中国远超欧美(图) UFC签下中国草量级女将 8月份洛杉矶上演首秀 梅西世界杯行程已经曝光 他已为世界杯做好准备 下台后第一次 穆加贝在妻子陪同下参加选举投票 萨法洛娃赞小德和捷克猛将合作 称进展会很顺利
张凯丽:文艺工作者要做一个时刻充满正能量的人 经济学家:中国城市发展面临的问题是包容性变差 两家比特币矿机制造商拟赴港上市 各融资10亿美元 空姐顺风车遇害案:疑犯接单10分钟即注销滴滴 网贷平台任性清盘“套路深” 多地监管出台退出规范 标题党:赛季场均4三分57%命中率 逆天不? 于汉超:不能用前两场来断言恒大状态 憋着劲夺冠 分立24年后国地税为何重合并?专家:有利深化税改 人社部:确保2018年高校毕业生就业水平总体稳定 2017做什么生意有前景 利润最高的不起眼行业 小投资冷门暴利行业 中国食品品牌排行榜 AG亚游集团