[公开漏洞]建站之星Sitestar某注入漏洞修复不当可继续绕过#2

来源:WooYun 浏览:864次 时间:2014-07-06
做网站找雨过天晴工作室
建站之星Sitestar某注入漏洞修复不当可继续绕过#2 相关厂商: 建站之星 漏洞作者:′ 雨。 提交时间:2014-04-07 12:22 公开时间:2014-07-06 12:22 漏洞类型:SQL注射漏洞 危害等级:高 自评Rank:20 漏洞状态: 厂商已经确认 漏洞来源:http://www.wooyun.org Tags标签: 无 漏洞详情 披露状态:

2014-04-07:细节已通知厂商并且等待厂商处理中
2014-04-08:厂商已经确认,细节仅向厂商公开
2014-04-11:细节向第三方安全合作伙伴开放
2014-04-18:细节向核心白帽子及相关领域专家公开
2014-04-28:细节向普通白帽子公开
2014-05-18:细节向实习白帽子公开
2014-07-06:细节向公众公开

简要描述:

屌丝周末终于又放假了。
继续看看。
过滤不严。

详细说明:

WooYun: 建站之星 Sitestar 注入漏洞一枚

这个漏洞发布的补丁过滤不完善。



看看发布的补丁修改的地方

foreach ($roles as $k=>$row){
//2014.3.31 filter roles
if(!in_array($row, $uall_roles)){ die('access violation error!');}





这里过滤了。 但是只过滤了这一处。 在其他地方 还能注入。



if (!empty($type) && $type=='single') {//单个邮件发送
if (empty($user_email)) {
echo "<script>alert('".__("Enter Username please")."');history.go(-1);</script>";
exit;
}
if (strstr($user_email,'|')) {//如果是多个用户
$users = explode('|',$user_email);
foreach ($users as $u){
$sql = "select id,email,login from ".Config::$tbl_prefix."users where login='".$u."'";

$res = $db->query($sql);
$eml = $res->fetchRow();





这里并没有过滤。

漏洞证明:

JT69P[M8M55Q7U81Y{IA}(A.jpg





这里直接把语句输出出来。 不用多说了把。



修复方案:

过滤。



亲 还是把分数给高一点嘛。

版权声明:转载请注明来源 ′ 雨。@乌云 漏洞回应 厂商回应:

危害等级:中

漏洞Rank:5

确认时间:2014-04-08 11:19

厂商回复:

处理中谢谢

最新状态:

2014-04-11:补丁已经发布,请去官网更新补丁或下载最新安装包,谢谢。