zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    二次封装CoreData
    <html>
    [bzoj1031][JSOI2007]字符加密Cipher
    kernel build &amp; preempt-rt patch &amp; xenomai
    java 微信server录音下载到自己server
    shell文本过滤编程(十一):paste命令
    经验总结21--抓取WEB数据,汇率,HtmlAgilityPack
    iOS 获取appstore 版本
    poj 3259 Wormholes 【SPFA&amp;&amp;推断负环】
    【ruby项目,语言提交检查(一)】怎样高速学习ruby ?
  • 原文地址:https://www.cnblogs.com/LittleHann/p/4281120.html
Copyright © 2011-2022 走看看