"; if (!isset($_POST['param'])) { die(); } else { $param = $_POST['param']; if (preg_match('/\>|\\\/', $param)) { die('not now'); } else if (preg_match('/ls|base|xxd|echo|cp|phpinfo|cat|\%|\^|\~|\$/i', $param)) { echo "almost there"; } else { exec($param); } } // /info.php will help!
时间: 2023-12-11 22:30:09 浏览: 249
php中$_REQUEST、$_POST、$_GET的区别和联系小结
5星 · 资源好评率100%
这是一段 PHP 代码,它接收一个名为 param 的 POST 请求参数。首先判断 param 是否存在,不存在则直接退出,否则将 param 赋值给 $param 变量。接着使用 preg_match 函数对 $param 进行正则匹配,如果匹配到 ">" 或者 "\",则退出程序;如果匹配到 "ls"、"base"、"xxd"、"echo"、"cp"、"phpinfo"、"cat"、"%"、"^"、"~"、"$" 等关键字,则输出 "almost there";否则执行 $param 命令,并输出结果。
这段代码的作用是实现一个简单的命令执行器,可以用于执行一些简单的命令。但是由于没有对输入参数进行充分的过滤和验证,存在命令注入等安全风险。建议对输入参数进行严格的过滤和验证,避免程序被攻击者利用。
阅读全文