命令执行及代码执行函数

命令执行函数

1. system:执行一个外部的应用程序并显示输出的结果
2. exec:执行一个外部的应用程序
3. shell_exec:执行shell命令并返回输出的结果的字符串
4. passthru:执行一个UNIX系统命令并显示原始的输出
5. popen()
6. proc_popen()

代码执行函数

1. eval(PHP代码)

payload:

<? eval('phpinfo();');?>
2. assert(PHP代码)

payload:

<? assert('phpinfo();');?>
3. preg_replace

preg_replace()函数的第一个参数存在e修饰符时,第二个参数和第三个参数可能当作PHP代码被执行
preg_replace漏洞触发有两个前提:
第一个参数需要e标识符,有了它可以执行第二个参数的命令
第一个参数需要在第三个参数中的中有匹配,不然echo会返回第三个参数而不执行命令
payload:

<?php preg_replace('/
(.∗)
/e','\\1','$_GET['a']);?>

请求1.php?a=[phpinfo()]

4. call_user_func()和array_map()

call_user_func()和array_map()等函数的作用就是调用其他函数,并将第二个参数作为回调函数的参数
payload:

<?php $b='phpinfo()'; 
call_user_func($_GET['a'],$b);?>
posted @ 2018-10-10 12:18  浅笑996  阅读(402)  评论(0编辑  收藏  举报