周五下午爆洞能不能让人们好好休个周末!
本次漏洞关键位置:/thinkphp/library/think/Request.php
,lines:501由图可以看到在method函数中引入了可控的数据来源:
data:image/s3,"s3://crabby-images/c1630/c1630f125e7d8613a4699a76b2922f67416d1967" alt=""
data:image/s3,"s3://crabby-images/56381/56381e094140678a88e6559016c3ff0f36e16c1c" alt=""
isset($_POST[Config::get('var_method')
$this->method
在取得该数据的值之后动态调用$this->{$this->method}($_POST)
,漏洞的关键位置即在该位置。攻击者调用该类任意函数,并通过$_POST
作为参数。动态调用__construct
函数即导致代码执行。
下图为Request类中包含的__construct
函数内容(lines:130):从中我们可以看到通过$options
参数,攻击者可以覆盖到filter、method
属性以及get属性的值。
data:image/s3,"s3://crabby-images/381e4/381e4d93b1c3f02b2fdab0784cef650930a5b82d" alt=""
同时在Request
当中的param
函数(lines:617)中可以看到当$this->arrayParam
为空时,即调用$this->get(false)
。
data:image/s3,"s3://crabby-images/03b26/03b26413d92ca12dc92c5614b6361b251dc43359" alt=""
$this->Get
函数(lines:673)内容如下:在get函数末端我们可以看到其调用了input
函数将攻击者可控的get
内容进行了传值。
data:image/s3,"s3://crabby-images/b9222/b9222308a84da9d2254644ce6d8cf81c5eb39281" alt=""
input
函数内容如下(lines:976):
data:image/s3,"s3://crabby-images/8e805/8e80588d8f7ee14f50ed02c669770b1d7615fe95" alt=""
我们可以看到getFilter
(lines:1005),继续跟踪至getFilter
函数(lines:1035):
data:image/s3,"s3://crabby-images/04fc6/04fc69ca7b9fe54b843c4b93f8486c1ea8a8bc2a" alt=""
Filter
返回后即进入input
函数中解析过滤器的if当中,紧接着其调用了filtervValue
函数(lines:1059):从中我们不难发现$filter
和$value
均可自行控制。
data:image/s3,"s3://crabby-images/27cfa/27cfa8e8dd11ad107543d7ea4859ba10382c4b15" alt=""
攻击还原(仅供技术交流,请勿非法测试)
data:image/s3,"s3://crabby-images/01357/013576489cdfc2c86830f136158abeaab95f16aa" alt=""
影响范围
5.0.X<Thinkphp<5.0.24
防御方案
版本升级到5.0.24最新版本规避漏洞
参考链接: https://github.com/top-think/framework/commit/4a4b5e64fa4c46f851b4004005bff5f3196de003?diff=split
网友评论