一、命令执行函数
system()
能够将字符串作为os命令执行,而且自带输出功能。
案例:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
system($_GET['cmd']);
echo "</pre>";
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/13534/13534e33c2298e1804a03e2c48510e7d7cbd319d" alt="在这里插入图片描述"
exec()
函数能够将字符串作为os命令执行,需要输出执行结果,但是只能显示命令的最后一行(如果是空行,直接不显示内容),适合单行结果的命令输出例如whoami
案例1:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
print exec($_GET['cmd']);
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/8b161/8b1611c47eb8ee2ee8cab801bd18dfc730f2cc5b" alt="在这里插入图片描述"
案例2:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
exec($_GET['cmd',$res]);
print_r($res);
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/ba5c9/ba5c96fdc8de05ddcdfa11ccb387c33c72a37ed4" alt="在这里插入图片描述"
shell_exec()
将函数中的参数当做os命令执行,本身不自带输出功能
案例1:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
print shell_exec($_GET['cmd']);
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/ac76d/ac76d9cac9a604f8c87bec280150a760e132d0ac" alt="在这里插入图片描述"
passthru()
函数本身自带输出功能。
案例1:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
passthru($_GET['cmd']);
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/60b0d/60b0ddca7517bf56b031a28dc560f463ace16ba5" alt="在这里插入图片描述"
popen()
函数没有回显,不会显示执行结果,但可以用来执行一些在服务器不需要回显的命令,比如md,也可以利用重定向的方式将有回显的数据导出到服务器端文件中。
案例1:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
popen($_GET['cmd'],'r');
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/b9468/b94687ee48044f897b8be7bf66cd0d40bcacdc4b" alt="在这里插入图片描述"
反引号 ``
案例1:
<?php
if(isset($_GET['cmd'])){
$info = $_GET['cmd'];
print `$info`;
}else{
echo "Useage:http://IpAddress/?cmd=ipconfig";
}
?>
data:image/s3,"s3://crabby-images/b3aa4/b3aa4b6437f3dcb00256611b0b07054594da5103" alt="在这里插入图片描述"
二、代码执行函数
php中有很多函数,可以将(符合PHP语法规范)字符串当作PHP代码执行。
eval()
将符合PHP语法规范的字符串当作php代码执行,eval()执行的字符串要以分号结束
案例1:
<?php
if(isset($_GET['cmd'])){
echo "<pre>";
@eval($_GET['cmd']);
}else{
echo "Useage:http://IpAddress/?cmd=net user";
}
?>
data:image/s3,"s3://crabby-images/dafe6/dafe6aa28587944e794fe613ce85b7ce02739361" alt="在这里插入图片描述"
案例2:
<?php
$str = "phpinfo();";
eval($str);
?>
data:image/s3,"s3://crabby-images/b2e40/b2e405ae0a2ac628bfe63a791575bc1666e1b3b3" alt="在这里插入图片描述"
案例3:对于特殊编码的支持
<?php
$str1 =chr(115).chr(121).chr(115).chr(116).chr(101).chr(109).chr(40).chr(39).chr(110).chr(101).chr(116).chr(32).chr(117).chr(115).chr(101).chr(114).chr(39).chr(41).chr(59);
print($str1);
eval($str1);
?>
data:image/s3,"s3://crabby-images/5721f/5721f95f3df5160f932f7711e1ffa4df1de1f9ca" alt="在这里插入图片描述"
案例4:
<?php
print(base64_encode("system('net user');"));
eval(base64_decode("c3lzdGVtKCduZXQgdXNlcicpOw"));
?>
data:image/s3,"s3://crabby-images/03d82/03d82756a7cd4bc25f4958a6043701992af211e0" alt="在这里插入图片描述"
assert()
同样会将字符串当做php代码执行
案例1:
<?php
if(isset($_GET['code'])){
$code=$_GET['code'];
assert($code);
}else{
echo "please submit code!<br>?code=phpinfo()";
}
?>
data:image/s3,"s3://crabby-images/27ccf/27ccf705d4b9bb3b9511ab4cd49da19e6005c266" alt="在这里插入图片描述"
preg_replace()
对字符串进行正则匹配后进行替换
案例1:
<?php
print(preg_replace("/^a/", "A", "apache"));
echo "<br>";
print(preg_replace('/\[.*\]/','test','[phpinfo()]'));
echo "<br>";
echo preg_replace('/\[(.*)\]/','\\1','[phpinfo()]');
?>
data:image/s3,"s3://crabby-images/f6f18/f6f1864883428e8fb71f51fa8bbafec4d3602b12" alt="在这里插入图片描述"
总结
本文只介绍了几个比较简单和常见的PHP危险函数, 欢迎大佬多多指教!
|