dedeCMS /data/mysql_error_trace.php DB error raised PHP Code Injection Via /include/dedesql.class.php Log FIle Without Access Validation

目录

1. 漏洞描述
2. 漏洞触发条件
3. 漏洞影响范围
4. 漏洞代码分析
5. 防御方法
6. 攻防思考

1. 漏洞描述

dedecms采用面向对象封装的方式实现了功能操作的模块集中化,例如对于数据库管理

1. /include/dedesql.class.php: mysql数据库操作
2. /include/dedesqli.class.php: mysqli数据库操作

当发生数据库操作语句执行错误的时候,框架代码会集中对错误相关信息进行收集,并保存到一个指定的文件中(/data/mysql_error_trace.php),但是这里存在一个安全上的漏洞

1. MySQL字段数值采用了C语言同样的定义,当传入的数值大于字段定义的类型的时候,将引发整型上溢出错误

2. /data/mysql_error_trace.php没有进行正确的访问认证
/*
security practice
在不需要被访问的日志文件头应该加上以下代码
die('Request Error!');
or
exit();
*/

3. 日志文件最好使用例如".txt"的文本文件进行保存

真正导致漏洞的原因是数据库处理库(/include/dedesql.class.php),而触发这个漏洞的文件有很多,攻击向量路径很多,理论上只要调用了如下代码即存在漏洞

/*
$dsql->ExecuteNoneQuery("Update `$maintable` set scores = scores + {$cfg_caicai_add},goodpost=goodpost+1,lastpost=".time()." where id=$id");
*/

目前已知的可以成为攻击向量的文件有

1. /plus/digg_frame.php
2. /plus/digg_ajax.php
3. /plus/comments_frame.php

Relevant Link:

http://icarusli.iteye.com/blog/610715
http://www.007hack.com/?p=522


2. 漏洞触发条件
3. 漏洞影响范围

1. < dede 5.7


4. 漏洞代码分析

/include/dedesql.class.php

//显示数据链接错误信息
function DisplayError($msg)
{
    $errorTrackFile = dirname(__FILE__).'/../data/mysql_error_trace.inc';
    //这里将日志文件的后缀改为了.inc,是一个好的防御方法
    if( file_exists(dirname(__FILE__).'/../data/mysql_error_trace.php') )
    {
        @unlink(dirname(__FILE__).'/../data/mysql_error_trace.php');
    }
    $emsg = '';
    $emsg .= "<div><h3>DedeCMS Error Warning!</h3>
";
    $emsg .= "<div><a href='http://bbs.dedecms.com' target='_blank' style='color:red'>Technical Support: http://bbs.dedecms.com</a></div>";
    $emsg .= "<div style='line-helght:160%;font-size:14px;color:green'>
";
    $emsg .= "<div style='color:blue'><br />Error page: <font color='red'>".$this->GetCurUrl()."</font></div>
";
    $emsg .= "<div>Error infos: {$msg}</div>
";
    $emsg .= "<br /></div></div>
";

    echo $emsg;

    $savemsg = 'Page: '.$this->GetCurUrl()."
Error: ".$msg;
    //保存MySql错误日志
    $fp = @fopen($errorTrackFile, 'a');
    //直接将错误信息写入了可执行的.PHP文件中
    @fwrite($fp, '<'.'?php'."
/*
{$savemsg}
*/
?".">
");
    @fclose($fp);
}


5. 防御方法

//显示数据链接错误信息
    function DisplayError($msg)
    {
        $errorTrackFile = dirname(__FILE__).'/../data/mysql_error_trace.inc';
        if( file_exists(dirname(__FILE__).'/../data/mysql_error_trace.php') )
        {
            @unlink(dirname(__FILE__).'/../data/mysql_error_trace.php');
        }
        $emsg = '';
        $emsg .= "<div><h3>DedeCMS Error Warning!</h3>
";
        $emsg .= "<div><a href='http://bbs.dedecms.com' target='_blank' style='color:red'>Technical Support: http://bbs.dedecms.com</a></div>";
        $emsg .= "<div style='line-helght:160%;font-size:14px;color:green'>
";
        $emsg .= "<div style='color:blue'><br />Error page: <font color='red'>".$this->GetCurUrl()."</font></div>
";
        $emsg .= "<div>Error infos: {$msg}</div>
";
        $emsg .= "<br /></div></div>
";
        
        echo $emsg;
        
        $savemsg = 'Page: '.$this->GetCurUrl()."
Error: ".$msg."
Time".date('Y-m-d H:i:s');
        //保存MySql错误日志
        $fp = @fopen($errorTrackFile, 'a');
        @fwrite($fp, '<'.'?php' . "
" . "die('Request Error!');" . "
/*
{$savemsg}
*/
?".">
");
        @fclose($fp);
    }

6. 攻防思考

Copyright (c) 2014 LittleHann All rights reserved

原文地址:https://www.cnblogs.com/LittleHann/p/4281120.html