PHP新用法,PHP执行体系外部命令篇






  PHP作为一种服务器真个脚本语言,象编写简单,或者是庞杂的动态网页这样的义务,它完整可能胜任。但事件不老是如斯,有时为了实现某个功效,必须借助于操作系统的外部程序或者称之为命令,这样可以做到事半功倍。
  
  那么,是否可以在PHP脚本中调用外部命令呢·如果能,如何去做呢·有些什么方面的顾虑呢·信任你看了本文后,肯定可以答复这些问题了。
  
  是否可以·
  谜底是确定的。PHP和其它的程序设计语言一样,完全可以在程序内调用外部命令,并且是很简单的:只有用一个或多少个函数即可。
  
  
条件前提
  因为PHP基础是用于WEB程序开发的,所以安全性成了人们考虑的一个主要方面。于是PHP的设计者们给PHP加了一个门:安全模式。如果运行在安全模式下,那么PHP脚本中将受到如下四个方面的限度:
  
  
执行外部命令
  在打开文件时有些制约
  
  衔接MySQL数据库
  
  基于HTTP的认证
  
  在安全模式下,只有在特定目录中的外部程序才可以被执行,对其它程序的调用将被谢绝。这个目录可以在php.ini文件顶用safe_mode_exec_dir指令,或在编译PHP是加上withexecdir选项来指定,默认是/usr/local/php/bin。
  
  如果你调用一个应当可以输出结果的外部命令意思是PHP脚本没有过错,得到的却是一片空缺,那么很可能你的网管已经把PHP运行在安全模式下了。
  
  如何做
  在PHP中调用外部命令,可以用如下三种方法来实现:
  
  
1 用PHP供给的专门函数
  PHP提供共了3个专门的执行外部命令的函数:system(),exec(),passthru()。
  
  system()
  
  原型:string system (string mand ., int return_var.)
  
  system()函数很其它语言中的差未几,它执行给定的命令,输出和返回结果。第二个参数是可选的,用来得到命令执行后的状态码。
  
  例子:
  
  system("/usr/local/bin/webalizer/webalizer");
  
  >
  
  exec()
  
  原型:string exec (string mand ., string array ., int return_var..)
  
  exec()函数与system()相似,也执行给定的命令,但不输出结果,而是返回成果的最后一行。固然它只返回命令结果的最后一行,但用第二个参数array能够得到完全的结果,方式是把结果逐行追加到array的结尾处。所以假如array不是空的,在调用之前最好用unset()最它清掉。只有指定了第二个参数时,才可以用第三个参数,用来获得命令履行的状况码。
  
  例子:
  
  exec("/bin/ls l");
  
  exec("/bin/ls l", $res);
  
  #$res是一个数据,每个元素代表结果的一行
  
  exec("/bin/ls l", $res, $rc);
  
  #$rc的值是命令/bin/ls l的状态码。胜利的情形下通常是0
  
  >
  
  passthru()
  
  原型:void passthru (string mand ., int return_var.)
  
  passthru()只调用命令,不返回任何结果,但把命令的运行结果原样地直接输出到尺度输出装备上。所以passthru()函数常常用来调用象pbmplusUnix下的一个处置图片的工具,输出二进制的原始图片的流这样的程序。同样它也可以得到命令执行的状态码。
  
  例子:
  
  header("Contenttype: image/gif");
  
  passthru("./ppmtogif hunte.ppm");
  
  >
  
  
2 用popen()函数翻开过程
  上面的方法只能简单地执行命令,却不能与命令交互。但有些时候必须向命令输入一些货色,如在增添Linux的系统用户时,要调用su来把当前用户换到root才行,而su命令必需要在命令行上输入root的密码。这种情况下,用上面提到的方法显然是不行的。
  
  popen()函数打开一个进程管道来执行给定的命令,返回一个文件句柄。既然返回的是一个文件句柄,那么就可以对它读和写了。在PHP3中,对这种句柄只能做单一的操作模式,要么写,要么读;从PHP4开端,可以同时读跟写了。除非这个句柄是以一种模式读或写打开的,否则必需调用pclose()函数来封闭它。
  
  例子1:
  
  $fppopen("/bin/ls l", "r");
  
  >
  
  例子2本例来自PHP中国同盟网站www.phpx./show.phpdcol
  
  $useradd "useradd ";
  
  $rootpasswd "verygood";
  
  $user "james";
  
  $user_add sprintf("s "s s"",$sumand,$useradd,$user);
  
  $fp popen($user_add,"w");
  
  fputs($fp,$rootpasswd);
  
  pclose($fp);
  
  >
  
  
3 用反撇,`,也就是键盘上ESC键下面的那个,和~在统一个上面
  这个办法以前没有纳入PHP的文档,是作为一个秘技存在的。方法很简略,用两个反撇,把要执行的命令括起来作为一个抒发式,这个表白式的值就是命令执行的结果。如:
  
  $res`/bin/ls l`;
  
  echo \'
  \'.$res.\'
  
  >
  
  这个脚本的输出就象:
  
  hunte.gif
  
  hunte.ppm
  
  jpg.htm
  
  jpg.jpg
  
  passthru.php
  
  要考虑些什么·
  
  要斟酌两个问题:平安性和超时。
  
  先看保险性。比方,你有一家小型的网上商店,所以可以出卖的产品列表放在一个文件中。你编写了一个有表单的HTML文件,让你的用户输入他们的EMAIL地址,而后把这个产品列表发给他们。假设你不应用PHP的mail()函数或者从未据说过,你就调用Linux/Unix系统的mail程序来发送这个文件。程序就象这样:
  
  system("mail $to

10-05 21:05