在PHP中执行服务器命令,可以用如下三种方法来实现:
2)system()原型:stringsystem(string$command[,int&$return_var])说明:system和exec的区别在于,system在执行系统外部命令时,直接将结果输出到游览器,如果执行命令成功则返回true,否则返回false。第二个参数与exec第三个参数含义一样。
3)passthru()原型:voidpassthru(string$command[,int&$return_var])说明:passthru与system的区别,passthru直接将结果输出到游览器,不返回任何值,且其可以输出二进制,比如图像数据。第二个参数可选,是状态码。
4)shell_exec()原型:stringshell_exec(string$cmd)说明:直接执行命令$cmd
方法三:用popen()函数打开进程原型:resourcepopen(string$command,string$mode)说明:能够和命令进行交互。之前介绍的方法只能简单地执行命令,却不能与命令交互。有时须向命令输入一些东西,如在增加系统用户时,要调用su来把当前用户换到root用户,而su命令必须要在命令行上输入root的密码。这种情况下,用之前提到的方法显然是不行的。
要考虑两个问题:安全性和超时1)安全性由于PHP基本是用于WEB程序开发的,所以安全性成了人们考虑的一个重要方面。于是PHP的设计者们给PHP加了一个门:安全模式。如果运行在安全模式下,那么PHP脚本中将受到如下四个方面的限制:执行外部命令在打开文件时有些限制连接MySQL数据库基于HTTP的认证在安全模式下,只有在特定目录中的外部程序才可以被执行,对其它程序的调用将被拒绝。
领取专属 10元无门槛券
私享最新 技术干货