PHP 危险函数1-OS 命令执行函数

本文介绍了PHP中的几种执行OS命令的方法,包括system(),exec(),shell_exec(),passthru(),popen()以及反引号的使用,强调了它们的特点,如自动输出、手动输出和交互性,并提供了动态执行命令的示例。
摘要由CSDN通过智能技术生成

OS 命令执行函数

system 函数

  • 特点:

    • 自带输出功能
    • 自动区分系统平台,只需得知目标系统在 system() 中输入对应系统的命令即可
  • 使用

    <?php
    	system("<系统命令>");  
    ?>
    

    <pre>
    <?php
    	system("ipconfig");  
    ?>
    

    image-20231025104714862

  • 动态执行命令

    <pre>
    <?php
    	$cmd = $_REQUEST['cmd'];
    	system($cmd);  
    ?>
    

    image-20231025105048955

exec 函数

  • 特点:

    • 不自带输出,需要手动输出
    • 只能输出命令执行的最后一行,几乎没有回显
  • 使用

    <?php
    	exec("<系统命令>");  
    	// 输出需手动
    ?>
    
  • <?php
    	exec("ipconfig");  
    	// 输出需手动
    ?>
    

    不自动回显,但执行

    image-20231025105444444

  • 回显(只有最后一行)

    <?php
    	echo exec("ipconfig");  
    ?>
    

    image-20231025105524160

  • 动态执行命令

    <?php
    	$cmd=$_REQUEST['cmd'];
    	echo exec($cmd);
        ?>
    

    image-20231025110155444

    image-20231025110219981

shell_exec 函数

  • 需要手动输出命令执行结果。

  • 使用

    <?php
    	shell_exec("<命令>");
        ?>
    
  • 示例

    <?php
    	$cmd=$_REQUEST['cmd'];
    	echo shell_exec($cmd);
        ?>
    

    image-20231025112650395

passthru 函数

  • 自带输出功能。

    <?php
        passthru("<命令>");
        ?>
    
  • <?php
        passthru("net user");
        ?>
    

    image-20231025113639532

  • 动态执行

    <?php
    	$cmd=$_REQUEST['cmd'];
    	echo passthru($cmd);
        ?>
    

    image-20231025113856701

popen 函数

  • 在 PHP 中,popen() 函数用于打开一个管道,并返回一个指向该管道的文件指针。允许在 PHP 脚本中执行外部命令或程序,并与其进行交互。

  • 注意,两个参数

    <?php
    	popen(<命令>,"r");  // read,以读取的方式打开
    ?>
    
  • 示例

    <?php
    	$cmd = $_REQUEST['cmd'];
    	$result = popen($cmd, 'r');
    	echo fread($result, 1024);
    	// fread() 函数从管道中读取最多 1024 字节的输出
        ?>
    

    image-20231025114936563

反引号

  • 反引号``内的字符串,会被解析成OS 命令。

  • 不自动输出

  • 使用

    <?php
        `<命令>`;
    ?>
    
  • 示例

    <?php
        echo `whoami`;
    ?>
    

    image-20231025115326998

  • 动态执行

    <pre>
    <?php
    	$cmd=$_REQUEST['cmd'];
    	echo `$cmd`;
        ?>
    

    image-20231025115520966

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

gjl_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值