PHP 执行系统外部命令 system() exec() passthru()

PHP中调用外部命令,可以用如下三种方法来实现:
方法一:用PHP提供的专门函数(四个):
PHP提供4个专门的执行外部命令的函数:exec(), system(), passthru(), shell_exec()
1)exec()
原型: string exec ( string $command [, array &$output [, int &$return_var ]] )
说明: exec执行系统外部命令时不会输出结果,而是返回结果的最后一行。如果想得到结果,可以使用第二个参数,让其输出到指定的数组。此数组一个记录代表输出的一行。即如果输出结果有20行,则这个数组就有20条记录,所以如果需要反复输出调用不同系统外部命令的结果,最好在输出每一条系统外部命令结果时清空这个数组unset($output),以防混乱。第三个参数用来取得命令执行的状态码,通常执行成功都是返回0。
<?php
    exec("dir",$output);
    print_r($output);
?>
2)system()
原型: string system ( string $command [, int &$return_var ] )
说明: system和exec的区别在于,system在执行系统外部命令时,直接将结果输出到游览器,如果执行命令成功则返回true,否则返回false。第二个参数与exec第三个参数含义一样。
<?php
system("pwd");
?>
3)passthru()
原型: void passthru ( string $command [, int &$return_var ] )
说明: passthru与system的区别,passthru直接将结果输出到游览器,不返回任何值,且其可以输出二进制,比如图像数据。第二个参数可选,是状态码。
<?php
header("Content-type:image/gif");
passthru("/usr/bin/ppm2tiff  /usr/share/tk8.4/demos/images/teapot.ppm");
?>
4)shell_exec()
原型: string shell_exec ( string $cmd )
说明: 直接执行命令$cmd
<?php
$output = shell_exec('ls -lart');
echo "<pre>$output</pre>";
?>
方法二:反撇号
原型: 反撇号`(和~在同一个键)执行系统外部命令
说明: 在使用这种方法执行系统外部命令时,要确保shell_exec函数可用,否则是无法使用这种反撇号执行系统外部命令的。
<?php
    echo `dir`;
?>
方法三:用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) . "\n";
$read = fread($handle, 2096);
echo $read;
pclose($handle);
?>
要考虑两个问题:安全性和超时
1)安全性
由于PHP基本是用于WEB程序开发的,所以安全性成了人们考虑的一个重要方面 。于是PHP的设计者们给PHP加了一个门:安全模式。如果运行在安全模式下,那么PHP脚本中将受 到如下四个方面的限制:
执行外部命令
在打开文件时有些限制
连接MySQL数据库
基于HTTP的认证
在安全模式下,只有在特定目录中的外部程序才可以被执行,对其它程序的调用将被拒绝。这个目录可以在PhP.ini 文件中用safe_mode_exec_dir指令,或在编译PHP是加上--with-exec-dir选项来指定。
 当你使用这些函数来执行系统命令时,可以使用escapeshellcmd()和escapeshellarg()函数阻止用户恶意在系统上执行命令,escapeshellcmd()针对的是执行的系统命令,而escapeshellarg()针对的是执行系统命令的参数。这两个参数有点类似addslashes()的功能。
2)超时
    当执行命令的返回结果非常庞大时,可以需要考虑将返回结果输出至其他文件,再另行读取文件,这样可以显著提高程序执行的效率。
如果要执行的命令要花费很长的时间,那么应该把这个命令放到系统的后台去运行。但在默认情况下,象system()等函数要等到这个命令运行完才返回(实际上是在等命令的输出结果),这肯定会引起PHP脚本的超时。解决的办法是把命令的输出重定向到另外一个文件或流中,如:
<?php
system("/usr/local/bin/order_proc  >  /tmp/abc ");
?>

  

但我调用的DOS命令需要几分钟的时间,而且为了批处理不能简单的把结果写入文件了事,要顺序执行以下的程序

PHP设置了调用系统命令的时间限制,如果调用命令超时,虽然这个命令还是会被执行完,但PHP没有得到返回值,被终止了(最可恨的是,不显示任何错误)

修改php.ini并重启Apache以允许系统命令运行更长的时间

max_execution_time = 600

 

转载于:https://www.cnblogs.com/datang6777/p/7003177.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/269180.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql使用IS NULL查询null值

mysql使用IS NULL查询null值

Huawei S8512

用户不能在同一单板上同时设置组播抑制功能和广播抑制功能&#xff0c;即一旦某单板有端口设置为广播抑制&#xff0c;该单板其他端口也不能设置组播抑制&#xff0c;反之亦然。只有单板所有端口均设置为广播抑制或组播抑制的默认抑制值时&#xff0c;端口才能修改为不同抑制功…

Python---时间函数

在Python中日期和时间可能涉及多个不同的数据类型和函数&#xff0c;本文将简要介绍一下。 一. 三种不同的数据类型 1. 时间戳&#xff1a;Unix纪元时间戳&#xff08;time模块中使用&#xff09;是一个浮点值或整型值&#xff0c;表示子1970年1月1日午夜0点&#xff08;UTC&am…

click 模拟单击一个对象

document.all.LABELID.click()

Spring Security 入门(1-9)国际化的使用

转载于:https://www.cnblogs.com/lexiaofei/p/7016222.html

asp存储过程使用大全

1&#xff0c;调用没有参数的存储过程<%set connserver.CreateObject("adodb.connection")set cmdserver.CreateObject("adodb.command")strconn"dsnpubs;uidsa;pwd"conn.Open strconnset cmd.ActiveConnectionconncmd.CommandText"{cal…

html5 文档元素 header footer h1h2h4

文档元素: 用于在页面的大布局, 区分各个主体和概念. 让整体清晰, 元素有语义, 进一步代替div 具体划分图示: (参考) <hgroup> <section> <nav> <article> 里面又是一个可以添加<header\section\footer>的一整套的标签, 麻雀虽小五脏俱全 &l…

基于Java SSM框架实现医院挂号上班打卡系统项目【项目源码+论文说明】计算机毕业设计

基于java的SSM框架实现医院挂号上班打卡系统演示 摘要 在网络发展的时代&#xff0c;国家对人们的健康越来越重视&#xff0c;医院的医疗设备更加先进&#xff0c;医生的医术、服务水平也不断在提高&#xff0c;给用户带来了很大的选择余地&#xff0c;而且人们越来越追求更个…

各类防火墙应用对比分析

各类防火墙应用对比分析 用户的网络拓扑结构的简单与复杂、用户应用程序的难易程度不是决定是否应该使用防火墙的标准&#xff0c;决定用户是否使用防火墙的一个根本条件是用户对网络安全的需求&#xff01;一、两种设备产生和存在的背景…

CAN 设备通讯实验代码+HAL 与原生库分别实现

实验准备&#xff1a; 两块带有CAN 收发器的STM32 MCU板子 1.HAL 库实现部分 pin 设置&#xff0c;依据datasheet 和原理图 时钟设置 工程设置 1&#xff09; main.c /* USER CODE BEGIN Header */ /*********************************************************…

Spring AOP 面向切面编程

AOP 在软件业&#xff0c;AOP为Aspect Oriented Programming的缩写&#xff0c;意为&#xff1a;面向切面编程&#xff0c;通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续&#xff0c;是软件开发中的一个热点&#xff0c;也是Spring框架中的…

分析 C# 2.0 新特性 -- 空类型(Nullable Types)

分析 C# 2.0 新特性 -- 空类型&#xff08;Nullable Types) 在讨论C# 2.0 空类型前&#xff0c;先回顾一下.NET 1.0和.NET 1.1对于类型有下面这样的定义&#xff1a; ".NET 中类型分为值类型和引用类型&#xff0c;值类型不能为空&#xff0c;引用类型可为空"; 在这…

qt websocket 通讯实现消息发送接收

websocket 是基于 TCP socket 之上的应用层&#xff0c; 解决 HTML 轮询连接的问题&#xff0c;实现客户端与服务端长连接&#xff0c; 实现消息互相发送&#xff0c;全双工。 服务端&#xff0c; 使用 QT 教程demo chatserver.h #ifndef CHATSERVER_H #define CHATSERVER_H#i…

关于人工智能引擎的最初分析文档

关于人工智能引擎的最初分析文档 赵立 1、开发人工智能引擎的目的是什么&#xff1f;其功能定位什么&#xff1f;有什么特色&#xff1f; 希望开发一整套人工智能软件的开发平台&#xff0c;用于解决目前软件技术难以处理的智能问题&#xff0c;从而能逐渐形成这方面的标准。我…

关于颜色值透明度的设置

<!--百分比-开头字母--> <!--100% —FF--> <!--95% — F2--> <!--90% — E6--> <!--85% — D9--> <!--80% — CC--> <!--75% — BF--> <!--70% — B3--> <!--65% — A6--> <!--…