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

OS 命令执行函数

system 函数

  • 特点:

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

    php 复制代码
    <?php
    	system("<系统命令>");  
    ?>

    php 复制代码
    <pre>
    <?php
    	system("ipconfig");  
    ?>
  • 动态执行命令

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

exec 函数

  • 特点:

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

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

    不自动回显,但执行

  • 回显(只有最后一行)

    php 复制代码
    <?php
    	echo exec("ipconfig");  
    ?>
  • 动态执行命令

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

shell_exec 函数

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

  • 使用

    php 复制代码
    <?php
    	shell_exec("<命令>");
        ?>
  • 示例

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

passthru 函数

  • 自带输出功能。

    php 复制代码
    <?php
        passthru("<命令>");
        ?>
  • php 复制代码
    <?php
        passthru("net user");
        ?>
  • 动态执行

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

popen 函数

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

  • 注意,两个参数

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

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

反引号

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

  • 不自动输出

  • 使用

    php 复制代码
    <?php
        `<命令>`;
    ?>
  • 示例

    php 复制代码
    <?php
        echo `whoami`;
    ?>
  • 动态执行

    php 复制代码
    <pre>
    <?php
    	$cmd=$_REQUEST['cmd'];
    	echo `$cmd`;
        ?>
相关推荐
欧阳潇瑞12 分钟前
ubuntu磁盘挂载
linux·运维·服务器
百锦再24 分钟前
Android Studio 中文字大小的单位详解
android·xml·java·ide·app·android studio
隐-梵28 分钟前
Android studio前沿开发--利用socket服务器连接AI实现前后端交互(全站首发思路)
android·服务器·人工智能·后端·websocket·android studio·交互
四岁爱上了她37 分钟前
CentOS更换yum源
linux·运维·centos
m0_zj40 分钟前
41.[前端开发-JavaScript高级]Day06-原型关系图-ES6类的使用-ES6转ES5
开发语言·javascript·es6
海棠蚀omo44 分钟前
C++笔记-list
开发语言·c++·笔记
烟雨柳成烟1 小时前
C++学习Day0:c++简介
开发语言·c++·qt·学习
再学一丢丢1 小时前
LVS+Keepalived+dns高可用项目架构
运维·服务器
鸿蒙布道师1 小时前
鸿蒙NEXT开发图片相关工具类(ArkTs)
android·ios·华为·harmonyos·arkts·鸿蒙系统·huawei
奔跑吧 android1 小时前
【android telecom 框架分析 01】【基本介绍 2】【BluetoothPhoneService为何没有源码实现】
android·telecom·phone·btphone