zoukankan      html  css  js  c++  java
  • PHP调用外部命令

    ------------------------------------------------------------------

    一、PHP调用外部命令总结                                                       

    二、安全问题

    三、超时问题

    ------------------------------------------------------------------

    一、PHP调用外部命令总结
    在PHP中调用外部命令,可以用,

    1>调用专门函数

    2>反引号

    3>popen()函数打开进程,三种方法来实现。

    1>专门函数

    php提供4种方法执行系统外部命令:exec()、passthru()、system()、 shell_exec()。
    在开始介绍前,先检查下php配置文件php.ini中是有禁止这是个函数。找到 disable_functions,配置如下:

    disable_functions =
    

    如果“disable_functions=”后面有接上面四个函数,将其删除。
    默认php.ini配置文件中是不禁止你调用执行外部命令的函数的。

     exec()

    function exec(string $command,array[optional] $output,int[optional] $return_value)
    

    php代码:

    1
    2
    3
    4
    5
    
    <?php
            echo exec("ls",$file);
            echo "</br>";
            print_r($file);
    ?>

    执行结果:

    test.php
    Array( [0] => index.php [1] => test.php)
    

    知识点:
    exec 执行系统外部命令时不会输出结果,而是返回结果的最后一行,如果你想得到结果你可以使用第二个参数,让其输出到指定的数组,此数组一个记录代表输出的一行,即如果输出结果有20行,则这个数组就有20条记录,所以如果你需要反复输出调用不同系统外部命令的结果,你最好在输出每一条系统外部命令结果时清空这个数组,以防混乱。第三个参数用来取得命令执行的状态码,通常执行成功都是返回0。

     passthru()

    function passthru(string $command,int[optional] $return_value)
    

    代码:

    1
    2
    3
    
    <?php
            passthru("ls");
    ?>

    执行结果:

    index.phptest.php
    

    知识点:
    passthru与system的区别,passthru直接将结果输出到浏览器,不需要使用 echo 或 return 来查看结果,不返回任何值,且其可以输出二进制,比如图像数据。

     system()

    function system(string $command,int[optional] $return_value)
    

    代码:

    1
    2
    3
    
    <?php
            system("ls /");
    ?>

    执行结果:

    binbootcgroupdevetchomeliblost+foundmediamntoptprocrootsbinselinuxsrvsystmpusrvar
    

    知识点:
    system和exec的区别在于system在执行系统外部命令时,直接将结果输出到浏览器,不需要使用 echo 或 return 来查看结果,如果执行命令成功则返回true,否则返回false。第二个参数与exec第三个参数含义一样。

     反撇号`和shell_exec()
    shell_exec() 函数实际上仅是反撇号 (`) 操作符的变体
    代码:

    1
    2
    3
    
    <?php
            echo `pwd`;
    ?>

    执行结果:

    /var/www/html
    

    2>反引号
    原型: 反撇号`(和~在同一个键)执行系统外部命令
    说明: 在使用这种方法执行系统外部命令时,要确保shell_exec函数可用,否则是无法使用这种反撇号执行系统外部命令的。
    <?php
        echo `dir`;
    ?>


    3>popen()函数打开进程
    原型: resource popen ( string $command , string $mode )
    说明: 能够和命令进行交互。之前介绍的方法只能简单地执行命令,却不能与命令交互。有时须向命令输入一些东西,如在增加系统用户时,要调用su来把当前用户换到root用户,而su命令必须要在命令行上输入root的密码。这种情况下,用之前提到的方法显然是不行的。
    popen( )函数打开一个进程管道来执行给定的命令,返回一个文件句柄,可以对它读和写。返回值和fopen()函数一样,返回一个文件指针。除非使用的是单一的模式打开(读or写),否则必须使用pclose()函数关闭。该指针可以被fgets(),fgetss(),fwrite()调用。出错时,返回FALSE。
    <?php
    error_reporting(E_ALL);
     
    /* Add redirection so we can get stderr. */
    $handle = popen('/path/to/executable 2>&1', 'r');
    echo "'$handle'; " . gettype($handle) . " ";
    $read = fread($handle, 2096);
    echo $read;
    pclose($handle);
    ?>

    二、安全问题

    由于PHP基本是用于WEB程序开发的,所以安全性成了人们考虑的一个重要方面。
    于是PHP的设计者们给PHP加了一个门:安全模式。
    在php.ini中的设置safe_mode = On
    如果运行在安全模式下,那么PHP脚本中将受到如下四个方面的限制:
        执行外部命令
        在打开文件时有些限制
        连接MySQL数据库
        基于HTTP的认证

    在安全模式下,只有在特定目录中的外部程序才可以被执行,对其它程序的调用将被拒绝。这个目录可以在php.ini文件中用safe_mode_exec_dir指令,或在编译PHP 是加上–with-exec-dir选项来指定,默认是/usr/local/php/bin。

     当你使用这些函数来执行系统命令时,可以使用escapeshellcmd()和escapeshellarg()函数阻止用户恶意在系统上执行命令,escapeshellcmd()针对的是执行的系统命令,而escapeshellarg()针对的是执行系统命令的参数。这两个参数有点类似addslashes()的功能。

    三、超时问题

     当执行命令的返回结果非常庞大时,可以需要考虑将返回结果输出至其他文件,再另行读取文件,这样可以显著提高程序执行的效率。
    如果要执行的命令要花费很长的时间,那么应该把这个命令放到系统的后台去运行。但在默认情况下,象system()等函数要等到这个命令运行完才返回(实际上是在等命令的输出结果),这肯定会引起PHP脚本的超时。解决的办法是把命令的输出重定向到另外一个文件或流中,如:
    <?php
    system("/usr/local/bin/order_proc > /tmp/abc ");
    ?>

    但我调用的DOS命令需要几分钟的时间,而且为了批处理不能简单的把结果写入文件了事,要顺序执行以下的程序
    PHP设置了调用系统命令的时间限制,如果调用命令超时,虽然这个命令还是会被执行完,但PHP没有得到返回值,被终止了(最可恨的是,不显示任何错误)
    修改php.ini并重启Apache以允许系统命令运行更长的时间
    max_execution_time = 600

  • 相关阅读:
    一个老菜鸟所理解的UX及产品流
    自学MVC看这里——全网最全ASP.NET MVC 教程汇总
    Windows10的革命之路-全新UWP开发平台
    七天学会ASP.NET MVC(七)——创建单页应用
    Windows10 会不会成为微软的新起点?
    Visual Studio 2015速递(4)——高级特性之移动开发
    Visual Studio 2015速递(3)——ASP.NET 新特性
    Visual Studio 2015速递(2)——提升效率和质量(VS2015核心竞争力)
    Visual Studio 2015速递(1)——C#6.0新特性怎么用
    Mac OS 环境下 安装 Asp.Net及使用Yeoman 创建Asp.Net 项目
  • 原文地址:https://www.cnblogs.com/peteremperor/p/6638937.html
Copyright © 2011-2022 走看看