当前位置:WooYun >> 漏洞信息

漏洞概要 关注数(24) 关注此漏洞

缺陷编号:wooyun-2014-068153

漏洞标题:TinyShop Sql Injection 1(无视GPC)

相关厂商:tinyrise.com

漏洞作者: xiaoL

提交时间:2014-07-22 18:11

修复时间:2014-10-20 18:12

公开时间:2014-10-20 18:12

漏洞类型:SQL注射漏洞

危害等级:高

自评Rank:20

漏洞状态:厂商已经确认

漏洞来源: http://www.wooyun.org,如有疑问或需要帮助请联系 [email protected]

Tags标签:

4人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

2014-07-22: 细节已通知厂商并且等待厂商处理中
2014-07-24: 厂商已经确认,细节仅向厂商公开
2014-07-27: 细节向第三方安全合作伙伴开放
2014-09-17: 细节向核心白帽子及相关领域专家公开
2014-09-27: 细节向普通白帽子公开
2014-10-07: 细节向实习白帽子公开
2014-10-20: 细节向公众公开

简要描述:

TinyShop Sql Injection 1(无视GPC)

详细说明:

后台登陆界面存在检查功能,不安全取值导致的SQL注入。

/controller/controller_class.php
public function check()
{

$this->safebox = Safebox::getInstance();
$this->title='后台登录';


$code = $this->safebox->get($this->captchaKey);
if($code != strtolower(Req::args($this->captchaKey)))
{
$this->msg='验证码错误!';
$this->layout = "";
$this->redirect('login',false);
}
else
{
$manager = new Manager(Req::args('name'),Req::args('password'));
$this->msg='验证码错误!';
if($manager->getStatus() == 'online')
{
$back = Req::args('callback');
$model = new Model("manager");
$model->data(array('last_ip'=>Chips::getIP(),'last_login'=>date("Y-m-d H:i:s")))->where("id=".$manager->id)->update();
//这里有一个getIP函数,跟入。
if($back === null) $back = $this->defaultAction;
$this->redirect($back,true);
}
else
{
$this->msg='用户名或者密码错误';
$this->layout = "";
$this->redirect('login',false);
}
}
}


getip函数跟进。
/framework/lib/util/chips_class.php
public static function getIP()
{
if (isset($_SERVER["HTTP_X_FORWARDED_FOR"]))$ip = $_SERVER["HTTP_X_FORWARDED_FOR"];
elseif (isset($_SERVER["HTTP_CLIENT_IP"])) $ip = $_SERVER["HTTP_CLIENT_IP"];
elseif (isset($_SERVER["REMOTE_ADDR"])) $ip = $_SERVER["REMOTE_ADDR"];
elseif (getenv("HTTP_X_FORWARDED_FOR")) $ip = getenv("HTTP_X_FORWARDED_FOR");
elseif (getenv("HTTP_CLIENT_IP")) $ip = getenv("HTTP_CLIENT_IP");
elseif (getenv("REMOTE_ADDR")) $ip = getenv("REMOTE_ADDR");
else $ip = "Unknown";
return $ip;
}
直接获取了$_SERVER["HTTP_X_FORWARDED_FOR"],gpc也没用了。导致了注入。我输出语句演示。

漏洞证明:

111.png


222.png

修复方案:

获取转义

版权声明:转载请注明来源 xiaoL@乌云


漏洞回应

厂商回应:

危害等级:低

漏洞Rank:3

确认时间:2014-07-24 09:47

厂商回复:

非常感谢您为TinyShop信息安全做的贡献
我们将尽快修复,非常感谢您的支持。

最新状态:

暂无


漏洞评价:

评论

  1. 2014-08-23 10:02 | Mutoubug ( 普通白帽子 | Rank:112 漏洞数:16 | <script>alert(wooyun);</script>)

    ORZ

  2. 2014-09-17 17:17 | chopper ( 普通白帽子 | Rank:144 漏洞数:29 | 菜鸟求学,多多关照~)

    ORZ