了解命令执行函数 system() passthru() 需回显示函数exec() shell_exec() ` `反引号
不会回显函数 popen(cmd,'r') 不常用函数proc_open() pcntl_exec() pcntl是linux下的一个拓展
system()
data:image/s3,"s3://crabby-images/8c061/8c061c37e6df27b14125b3c05b6969bb2e2ac9c9" alt=""
exec()
需要打印才能回显
data:image/s3,"s3://crabby-images/dd33e/dd33eff55c6dc28bf6bc2032b7407059f36f8743" alt=""
passthru()
data:image/s3,"s3://crabby-images/d7ec0/d7ec0688834a59f2603ae472b71b6716f95dd9bb" alt=""
shell_exec()
需要打印回显
data:image/s3,"s3://crabby-images/f2745/f2745134970710a2017e4dde0ca98975d5fe44f7" alt=""
` `反引号
需要打印回显
data:image/s3,"s3://crabby-images/d6bde/d6bde0d558c82266fccaa766b67e7d441dc6e444" alt=""
popen(cmd,'r')
不会有回显,但实际上已经执行成功了,需要 'r' 读取
php输出Resource id #2,这个结果表示的是输出一个记录集合
data:image/s3,"s3://crabby-images/fe0e2/fe0e2e63d4535c0e32dac8db97b012cff877933b" alt=""
pcntl_exec()
1、说明
pcntl是linux下的一个扩展,可以支持php的多线程操作。
pcntl_exec函数的作用是在当前进程空间执行指定程序,版本要求:PHP 4 >= 4.2.0, PHP 5
2、利用
在做渗透的时候被disable_functions卡住不能执行命令是家常便饭,今天在一国外虚拟主机上又被卡了,但我在执行phpinfo();的时候眼前闪过–enable-pcntl。当时我就偷笑了,没啥好说的,我一直强调渗透要细心做人做事也一样。
#exec.php
<?php cntl_exec(“/bin/bash”, array(“/tmp/b4dboy.sh”));?>
命令执行防御函数
escapeshellarg 转义
escapeshellcmd() 转义
然而escapeshellcmd()和escapeshellarg一起使用,会造成特殊字符逃逸
参考:https://paper.seebug.org/164/
网友评论