+ -
当前位置:首页 → 问答吧 → 第20章 使用PHP编写Shell

第20章 使用PHP编写Shell

时间:2007-11-09

来源:互联网

本章将介绍如何使用在标准命令行或Shell下执行PHP脚本,即PHP 5的CLI模式开发。
在这里您将了解到,PHP不仅仅可以在Web环境下运行,还可以脱离浏览器,在命令行和系统后台环境下很好地完成任务。
20.1 简介

一般情况下,PHP是运行于Web环境上的产品,与HTML标签混合开发,将结果显示在浏览器上,作为交互式脚本。PHP位于Web服务器(Apache、Microsoft IIS等)和用户之间的中间层,称为SAPI(Short for web server API)。在Web服务器上,PHP始终充当引用与用户界面的功能。
在本章,我们将共同了解CLI(short for Command Line Interface)的开发,讨论如何在命令行工具下执行,以及如何在单独的服务器进程下运行CLI脚本。
20.2 PHP CLI Shell脚本


20.2.1CLI 与CGI的区别


PHP CLI版本有些类似于PHP的CGI模式,尽管它们之间有很多共同的行为,但CLI和CGI是分属于不同的SAPI的。
CLI没有用到GET或POST表单处理,无MIME的头信息输出,以及其他隐含的SAPI实现。

20.2.2CLI的配置参数

下面是有关CLI SAPI运行对php.ini配置进行强制覆盖的参数,以适合运行在Shell环境或命令行环境下。


(1)CLI默认以安静模式开始,不会输出任何HTTP头信息。
(2)在运行时,不会把工作目录改为脚本的当前目录(可以使用-C和-no-chdir参数来兼容CGI模式)。
(3)出错时输出纯文本的错误信息(非HTML格式)。
(4)CLI SAPI强制覆盖了php.ini中一些参数的设置:
Øhtml_errors:CLI默认为False,不显示HTML格式错误;
Øimplicit_flush:CLI默认为True;
Ømax_execution_time:CLI默认为0(即没有超时限制);
Øregister_argc_argv:CLI默认为True,即通过argc传递参数。
关于implicit_flush和register_argc_argv介绍如下:
implicit_flush = On
强制flush(刷新),让PHP告诉输出层在每个输出块之后自动刷新自身数据,等效于在每个print()或echo()调用和每个HTML块后调用flush()函数。
register_argc_argv = On ;
这条命令告诉PHP是否声明argv和argc变量。变量“$argc”提供传递给应用程序的参数数量,数组“$argv”里保存着实际的参数值
Ø在PHP CLI下,有3个常量定义在Shell环境下,分别为STDIN、STDOUT和STDERR,包括了在Shell设备下文件处理的所有情况,如STDIN(标准输入):fopen('php://stdin', 'r')。因此,我们可以从STDIN读到一行数据,类似于$strLine = trim(fgets(STDIN));。

注意:STDIN已经定义在PHP CLI下。。



Ø在PHP 5.x版本后,已经修改了CLI与CGI的文件名,负责解释CGI版本的文件为php-cgi.exe,负责给CLI解释的文件为php.exe。
CLI模式对于开发如抓取网页信息等功能非常有用,可以不需要打开浏览器就运行某个PHP去抓取,也不会存在超时的情况。CLI模式在程序运行完之后,工作台界面会立即关闭,并且占用系统资源要比CGI方式小得多。
除了上述特征外,CLI脚本与Web下的PHP脚本没有什么不同,也需要用<?php ?>来包含代码。


20.3 PHP命令行接口(CLI)


如果开发环境是UNIX,要运行CLI,则需要在PHP编译时加入参数。比如,在FreeBSD环境下编译PHP,使用make config时需要选择CLI选项,如图20-1所示。

图20-1
并且将路径包含在系统的环境变量中,默认的路径是/usr/local/bin或/usr/bin。在UNIX系统下,一个简单的PHP CLI脚本的内容类似于下面的内容:
#!/usr/local/bin/php -q
复制PHP内容到剪贴板
PHP代码:

<?php
   echo "我是PHP CLI打印的内容!"; 
?>

Windows用户需要在第一行指定php.exe的位置,即可运行,如下面例子:
#!C:\php\php.exe -q
复制PHP内容到剪贴板
PHP代码:

<?php 
   echo "我是PHP CLI打印的内容!"; 
?>

在UNIX/Linux的Shell环境下执行时,需要把该文件置为可运行属性:
chmod u+rx phpCli.php //或使用755
执行该文件:
Php Cli.php
在Windows的命令行下可以直接执行该PHP文件,但事先声明一下PATH路径,或者加到系统环境变量中。



20.4 CLI命令选项

PHP CLI使用非常容易,同样,也非常稳定,它在命令行下提供很多灵活的选项。最简单的方法就是在命令行下输入(前提:需要设置PATH路径指向php-win.exe的位置),如下例:
php d:\cli\run.php
下面是关于CLI命令的语法格式:
Øphp [options] [-f] <file> [--] [args...]
Øphp [options] -r <code> [--] [args...]
Øphp [options] [-B <begin_code>] -R <code> [-E <end_code>] [--] [args...]
Øphp [options] [-B <begin_code>] -F <file> [-E <end_code>] [--] [args...]
Øphp [options] [--] [args...]
Øphp [options] -a
有关[option]选项可以使用下面的参数。
-a

交互式运行CLI程序
-c <path>|<file>
查找php.ini的路径
-n
不使用php.ini文件
-d action[=input]
定义INI的入口action的值为'input'
-e
对调试器(debugger)/解析器(profiler)生成扩展信息
-f <file>
解析文件 <file>
-h
显示帮助信息
-i
PHP 信息
-l
只进行语法检查,不执行
-m
显示在模块编译
-r <code>
运行 PHP <code> 用脚本标识 <?..?>
-B <begin_code>
运行PHP <begin_code> 在输入一行前
-R <code>
运行 PHP <code> 对输入的每一行
-F <file>
解析和执行 <file> 对输入的每一行
-E <end_code>
运行PHP <end_code> 在所有行输入后操作
-H
对外部工具隐含每个传递的参数
-s
对源代码语法显示高亮
-v
显示版本号
-w
源代码显示,不显示备注与空白字符
-z <file>

从 <file>调入Zend扩展
PHP CLI参数(args)通过标准输入(stdin)传递参数。
在Windows系统下,我们可以在命令行下显示PHP CLI的版本。
C:\php>php -v
PHP 5.2.1 (cli) (built: Feb
7 2007 23:11:26)
Copyright (c) 1997-2007 The PHP Group
Zend Engine v2.2.0, Copyright (c) 1998-2007 Zend Technologies
with Zend Extension Manager v1.0.11, Copyright (c) 2003-2006, by Zend Technologies
with Zend Optimizer v3.2.0, Copyright (c) 1998-2006, by Zend Technologies
在FreeBSD下的样式如下:
www# php -v
PHP 5.2.1 with Suhosin-Patch 0.9.3 (cli) (built: Jan
2 2007 00:12:32)
Copyright (c) 1997-2006 The PHP Group
Zend Engine v2.2.0, Copyright (c) 1998-2007 Zend Technologies
with eAccelerator v0.9.5-rc1, Copyright (c) 2004-2006 eAccelerator, by eAccelerator
with Zend Extension Manager v1.0.11, Copyright (c) 2003-2006, by Zend Technologies
with Zend Optimizer v3.2.0, Copyright (c) 1998-2006, by Zend Technologies

因为笔者的PHP 5中安装了eAccelerator缓存加速器,可能会与读者的系统显示稍有不同。

在命令行输出:php -a,它将允许我们与命令行进行交互,如图20-2所示。



图20-2
在输入语句时,如果遇到打印输出语句,PHP会随着输出的命令马上打印出来,这样在调试程序时又多了一个即时性。如果想退出该状态,按“Ctrl+C”组合键即可。
附件: 您所在的用户组无法下载或查看附件

作者: PHPChina   发布时间: 2007-11-09

20.5 CLI开发

PHP CLI模式开发不需要任何一种Web服务器(包括Apache或MS IIS等),这样,CLI可以运行在各种场合。
有两种方法可以运行PHP CLI脚本。
第一种方法是使用php -f /path/to/yourfile.php。调用PHP CLI解释器,并给脚本传递参数。这种方法首先要设置php解释器的路径,Windows平台在运行CLI之前,需设置类似path c:\php的命令,也失去了CLI脚本第一行的意义,因此不建议使用该方法。
第二种方法是首先运行chmod+x <要运行的脚本文件名>(UNIX/Linux环境),将该PHP文件置为可执行权限,然后在CLI脚本头部第一行加入声明(类似于#!/usr/bin/php或PHP CLI解释器位置),接着在命令行直接执行。这是CLI首选方法,建议采用。
下面我们来看看怎样编写PHP CLI脚本。
1.编写第一个CLI脚本首先创建一个名为myfile.php的PHP脚本,用于运行PHP CLI。该脚本很简单,仅显示“你好 PHP CLI!”。该脚本代码如下:
#!/usr/local/bin/php �Cq
复制PHP内容到剪贴板
PHP代码:

<?php
   //Windows平台上,上行应该为:#!C:\php\php.exe -q
   echo "你好 PHP CLI!";
?>

不要忘了给该文件设置为可执行的权限:
$ chmod 755 myfile.php
然后直接输入以下命令,按回车键即可以运行:
$ ./myfile.php
如果要在Windows系统下运行该脚本,则不需要设置文件属性,可以直接运行该脚本。
Microsoft Windows [版本 6.0.6000]
版权所有 (C) 2006 Microsoft Corporation。保留所有权利。

C:\ >myfile.php
你好 PHP CLI!
再重申一次:如果在Windows平台,CLI脚本的第一行一定要写正确php.exe所在的位置,像这样(另外,如果要在CLI脚本中加注释语句,则要把注释写在PHP标签里面,因为CLI解释只认识第一行,不在PHP标签里认为是语法错误):
#!C:\php\php.exe -q
这样,可以看到在命令行下信息已经打印出来,证明该CLI脚本已经成功运行。
2.从命令行上读取参数如果想从命令行获取参数,CLI可以从$_SERVER['argc']和$_SERVER['argv'']取得参数的个数和值。我们再建立一个文件,名字为testargs.php,脚本代码如下:
#!C:\php\php.exe �Cq
复制PHP内容到剪贴板
PHP代码:

<?php
   //UNIX和Linux平台下应该为#!/usr/local/bin/php �Cq
   echo "测试获取参数:\n";
   echo $_SERVER["argc"]."\n";
   //显示传入的参数值,从索引1开始显示
   echo $_SERVER["argv"][1]."\n";
   echo $_SERVER["argv"][2]."\n";
   echo $_SERVER["argv"][3]."\n";
   echo $_SERVER["argv"][4]."\n";
?>

在命令行输入如下代码:
C:\Users\John>testargs.php Always To Be Best
测试获取参数:
4
Always
To
Be
Best
因为我们输入了一串单词,为“Always To Be Best”,脚本参数以空格分隔。因此,PHP将其计为4个参数,下面对此说明。
$_SERVER["argc"]数组返回一个整型的数,代表从命令行上回车后一共输入了几个参数。
从上例的结果已经看出,要访问已经传入的参数值,需要从索引1开始。因为脚本本身的文件已经占用了索引0,即$_SERVER["argv"][0]。
3.处理I/O通道

PHP最初设计不是用于与用户直接的键盘输入或文本输出结合使用。了解这一设计是至关重要的,因为如果需要在命令行中执行任何操作,都必须能够与用户来回通信。
输入输出(I/O)通道这个思想来源于UNIX系统,UNIX系统提供3个文件句柄,用以从一个应用程序及用户终端发送和接收数据。
我们可以把一个脚本的输出重定向到一个文件:
php world.php > outputfile
如果是在UNIX系统下,也可以使用通道定向到另一个命令或应用程序中。例如:
php world.php | sort.
在PHP 5 CLI中,有一个文件流句柄,可以使用3个系统常量,分别为STDIN、STDOUT和STDERR。下面我们分别介绍。

(1)STDIN
STDIN全称为standard in或standard input,标准输入可以从终端取得任何数据。
格式:stdin ('php://stdin')
下面的例子是显示用户输入:
#!/usr/local/bin/php -q
复制PHP内容到剪贴板
PHP代码:

<?php
   $file = file_get_contents("php://stdin", "r");
   echo $file;
?>

这段代码的工作原理与cat命令很相似,回转提供给它的所有输入。但是,这时它还不能接收参数。
STDIN是PHP的标准输入设备,利用它,CLI PHP脚本可以做更多的事情。如下面例子:
#!/usr/local/bin/php -q
复制PHP内容到剪贴板
PHP代码:

<?php
   //UNIX平台下第一行应该为#!/usr/bin/php �Cq
   /* 如果STDIN未定义,将新定义一个STDIN输入流 */
   if(!defined("STDIN")) {
      define("STDIN", fopen('php://stdin','r'))
   } 
   echo "你好!你叫什么名字(请输入):\n";
   $strName = fread(STDIN, 100); //从一个新行读入80个字符
   echo '欢迎你'.$strName."\n";
?>

该脚本执行后将显示:
你好!你叫什么名字(请输入):
比如,输入Raymond之后,将显示:
欢迎你Raymond
(2)STDOUT
STDOUT全称为standard out或standard output,标准输出可以直接输出到屏幕(也可以输出到其他程序,使用STDIN取得),如果在PHP CLI模式里使用print或echo语句,则这些数据将发送到STDOUT。
格式:stdout ('php://stdout')
我们还可以使用PHP函数进行数据流输出。如下面例子:
#!/usr/local/bin/php �Cq
复制PHP内容到剪贴板
PHP代码:

<?php
   $STDOUT = fopen('php://stdout', 'w'); 
   fwrite($STDOUT,"Hello World"); 
   fclose($STDOUT); 
?>

输出结果如下:
Hello World
例如,echo和print命令打印到标准输出。
#!/usr/local/bin/php �Cq
Output #1.
复制PHP内容到剪贴板
PHP代码:

<?php 
   echo "Output #2.";
   print "Output #3."
?>

这将得到:
Output #1.
Output #2.Output #3.

说明:PHP标记外的新行已被输出,但是echo命令或print命令中没有指示换行。事实上,命令提示符重新出现在Output #2.Output #3. 所在的行中。PHP拥有的任何其他打印函数将会像此函数一样运行正常,任何写回文件的函数也是一样的。

#!/usr/local/bin/php -q

复制PHP内容到剪贴板
PHP代码:

<?php
   $STDERR = fopen('php://stderr', 'w'); 
   fwrite($STDERR,"There was an Error"); 
   fclose($STDERR); 
?>

以上代码将把php://stdout作为输出通道显式打开,并且php://output通常以与php://stdout相同的方法运行。
(3)STDERR
STDERR全称为standard error,在默认情况下会直接发送至用户终端,当使用STDIN文件句柄从其他应用程序没有读取到数据时会生成一个“stdin.stderr”。
格式:stderr ('php://stderr')
下面的脚本表示如何把一行文本输出到错误流中。
#!/usr/local/bin/php �Cq
复制PHP内容到剪贴板
PHP代码:

<?php
   $STDERR = fopen('php://stderr', 'w'); 
   fwrite($STDERR,"There was an Error"); 
   fclose($STDERR); 
?>

PHP 5.2可以直接使用STDOUT作为常量,而不是定义上面使用的变量$STDOUT,为了兼容之前版本,我们仍使用了自定义变量,如果您使用的是PHP 5.2,则可以参考STDIN的第二个例子。
4.后台运行CLI如果正在运行一个进程,而且在退出账户时该进程还不会结束,即在系统后台或背景下运行,那么就可以使用nohup命令。该命令可以在退出账户之后继续运行相应的进程。
nohup在英文中就是不挂起的意思(no hang up)。该命令的一般形式为:
nohup �Cf scriptname.php &
使用nohup命令提交作业,在默认情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件。
nohup scriptname.php > log.txt &
这样,PHP CLI脚本执行后的结果将输出到log.txt中,我们可以使用tail命令查看该内容:
tail -n50 -f log.txt
现在再来实现两个例子,第一个是每隔10分钟自动生成一个静态HTML文件,并一直执行下去。脚本代码如下:
#! /usr/local/bin/php
复制PHP内容到剪贴板
PHP代码:

<?php
   set_time_limit(0);
   while(true){
      @fopen("/usr/local/www/data-dist/content/article_".time().".html","w");
      sleep(600);
   }
?>

保存并且退出vi编辑器,然后赋予genHTML.php文件可执行权限:
#>chmod 755 genHTML.php
然后让脚本在后台执行,执行如下命令:
$nohup genHTML.php �Cf &
执行上述命令后出现如下提示:
[1] 16623
按回车键后将出现shell提示符。上面的提示就是说,所有命令执行的输出信息都会放到nohup.out文件中。
执行上面命令后,每隔10分钟就会在指定的目录生成指定的HTML文件,如article_111990120.html等文件。
如何终止CLI程序的后台运行呢?
可以使用kill命令来终止这个进程,终止进程之前要知道进程的PID号,即进程ID,我们使用ps命令:
www# ps

PID
TT
STAT
TIME COMMAND

561
v0
Is+
0:00.00 /usr/libexec/getty Pc ttyv0

562
v1
Is+
0:00.00 /usr/libexec/getty Pc ttyv1

563
v2
Is+
0:00.00 /usr/libexec/getty Pc ttyv2

564
v3
Is+
0:00.00 /usr/libexec/getty Pc ttyv3

565
v4
Is+
0:00.00 /usr/libexec/getty Pc ttyv4

566
v5
Is+
0:00.00 /usr/libexec/getty Pc ttyv5

567
v6
Is+
0:00.00 /usr/libexec/getty Pc ttyv6

568
v7
Is+
0:00.00 /usr/libexec/getty Pc ttyv7
16180
p0
I
0:00.01 su
16181
p0
S
0:00.06 _su (csh)
16695
p0
R+
0:00.00 ps
16623  p0  S     0:00.06 /usr/local/bin/php /usr/local/www/data/genHTML.php
已经看到PHP的进程ID是:16623,于是再执行kill命令:
$ kill -9 16623
[1]+  Killed                  nohup /usr/local/www/data/genHTML.php
这时该命令的进程就已经被终止了,再使用ps命令:
$ ps
PID  TT  STAT      TIME COMMAND
82374  p3  Ss     0:00.17 -bash (bash)
82535  p3  R+     0:00.00 ps
刚才的PHP CLI脚本已经没有了,如果直接运行ps命令无法看到进程,那么就结合使用ps & apos两个命令来查看。

注意:上面例子必须运行在UNIX或者Linux系统中,如FreeBSD、Redhat Linux等,在Windows环境不支持nohup命令。



20.6 CLI实际应用

以下是一个使用PHP编写对MySQL数据库备份的PHP CLI脚本程序(仅适用于UNIX或Linux系统,当然您可以改写和优化)。
#!/usr/local/bin/php �Cq
复制PHP内容到剪贴板
PHP代码:

<?php
   //配置数据库信息
   $dbhost = 'localhost';
   $dbuser = 'username';
   $dbpass = 'password';
   $mysqldump = '/usr/local/mysql/bin/mysqldump --opt --quote-names';

   //接受参数,如果参数不足,提示
   if ( count( $argv ) < 2 ) {
?>


backupDatabase.php
Create a backup of one or more MySQL databases.
Usage: <?=$argv[0]?> [$database] $path
$database -
Optional - if omitted, default is to backup all databases.
If specified, name of the database to back up.
$path -
The path and filename to use for the backup.
Example: /var/dump/mysql-backup.sql
复制PHP内容到剪贴板
PHP代码:

<?php
      exit();
   }

   //如果数据库的参数遗漏
   $database = NULL;
   $path = NULL;
   if ( count( $argv ) == 2 ) {
      $database = '--all-databases';
      $path = $argv[1];
   }
   else {
      $database = $argv[1];
      $path = $argv[2];
   }

   //构造命令
   $command = "$mysqldump -h $dbhost -u $dbuser -p $dbpass $database > $path";

   // create a version of the command without password for display
   $displayCommand = "$mysqldump -h $dbhost -u $dbuser -p $database > $path";
   print $displayCommand . '\n';

   //在shell运行该命令并且验证备份是否成功
   $result = shell_exec( $command );
   $verify = filesize( $path );
   if ( $verify ) {
      print "\nBackup complete ($verify bytes).\n";
   }
   else {
      print '\nBackup failed!!!\n';
   }
?>

处理目录属性的一个PHP Shell脚本(适用于UNIX和Linux系统):
#!/usr/local/bin/php -q
复制PHP内容到剪贴板
PHP代码:

<?php
   //预设置目录属性(样例)
   $presets = array( 'production-www'=>'root:www-0750',
                     'shared-dev'=>':www-2770',
                     'all-mine'=>'-0700'
   );

   //稍候再发送警告信息
   ob_start();
?>

resetPermissions.php
Changes file ownership and permissions in some location according
to a preset scheme.

Usage: <?=$argv[0]?> $location $preset

$location -
Path or filename. Shell wildcards allowed

$preset -
Ownership / group / permissions scheme, one of the following:
复制PHP内容到剪贴板
PHP代码:

<?php
   foreach( $presets AS $name=>$scheme ) {
      print $name . '<br />';
   }

   $usage = ob_get_contents();
   ob_end_clean();

   // provide usage reminder if script was invoked incorrectly
   if ( count($argv) < 2 ) {
      exit( $usage );
   }

   // 导入参数
   $location = $argv[1];
   $preset = $argv[2];
   if ( !array_key_exists( $preset, $presets ) ) {
      print 'Invalid preset.\n\n';
      exit( $usage );
   }

   // 解析参数 [[$owner]:$group][-$octalMod]
   // 第一个参数导入到变量$properties中
   $properties = explode( '-', $presets[$preset] );
   // determine whether chown or chgrp was requested
   $ownership = FALSE;
   $owner = FALSE;
   $group = FALSE;
   if ( !empty($properties[0]) ) {
      $ownership = explode( ':', $properties[0] );
      if ( count( $ownership ) > 0 ) {
         $owner = $ownership[0];
         $group = $ownership[1];
      }
      else {
         $group = $ownership[0];
      }
   }

   // 检查chmod操作是否已经成功
   $octalMod = FALSE;
   if ( !empty( $properties[1] ) ) {
      $octalMod = $properties[1];
   }

   //执行相应的系统命令
   $result = NULL;
   if ( $owner ) {
      print "Changing ownership to $owner.\n";
      $result .= shell_exec( "chown -R $owner $location 2>&1" );
   }

   if ( $group ) {
      print "Changing groupership to $group.\n";
      $result .= shell_exec( "chgrp -R $group $location 2>&1" );
   }

   if ( $octalMod ) {
      print "Changing permissions to $octalMod.\n";
      $result .= shell_exec( "chmod -R $octalMod $location 2>&1" );
   }

   // 显示错误信息
   if ( !empty( $result ) ) {
      print "\nOperation complete, with errors:\n$result\n";
   }else {
      print 'Done.\n';
   }
?>



一个实用的文件压缩脚本:
#!/usr/bin/php -q
复制PHP内容到剪贴板
PHP代码:

<?php 
   /* This first if is there to make sure that there are exactly two arguments. 
    * The first argument would be "backup.php" because thats the name of the script, 
    * The second argument would be the directory name that they want to back up 
   */ 

   if($_SERVER['argc'] != 2) {
      die('backup.php Expects Only one argument: Usage: backup.php <directoryname>') 
   } 

   /* This tests to see if the file really exists using file_exists() 
    * And that its a directory using is_dir(), if the file doesn't exist 
    * or isn't a directory, it would die with an error 
   */ 

   if(!file_exists($_SERVER['argv'][1]) OR !is_dir($_SERVER['argv'][1])) { 
      die($_SERVER['argv'][1] . ' is not a valid directory'); 
   } 
   
   /* This will execute the linux command that should tar the the directory, 
    * Tar is a program a lot like zip that should shove the contents of the directory 
    * into a "backup.tar" file. 
   */ 

   exec('tar -cvf backup.tar ' . $_SERVER['argv'][1]) or die('Tar failed!'); 
   echo "File Backed up to backup.tar Sucessfully!"; 
?>

20.7 小结

本章着重讲述了PHP在工作台下运行的CLI模式。
PHP的这种模式非常有用,使用它可以作为后端处理的应用,如果与UNIX的cron或Windows端的计划任务配合使用,则可以更大地发挥PHP的优势。

作者: PHPChina   发布时间: 2007-11-09

我的代码是
cli.php
复制PHP内容到剪贴板
PHP代码:
#!E:/APM/PHP/php.exe -q
<?php
echo 'hello';
?>
php.exe 的路径是 E:/APM/PHP/php.exe
cli.php 文件路径是 E:/www/test

我在cmd下进入E:/www/test,直接执行cli.php,但是程序没有被执行,而是调用了我的IDE把cli.php这个文件打开了……

请问问题可能出在哪里?

我的环境是APMserv 5.2.0集成包
php 5.2.1

PS: 使用 php -f 的形式就可以正确执行。

[ 本帖最后由 菜刀 于 2007-11-9 11:26 编辑 ]

作者: 菜刀   发布时间: 2007-11-09

这一章很新颖其它的书上没见过,很需要看一下

还是和以前一样发个电子版,希望大家能够好好学习。

不知道为什么这次PDF压缩就够了呢,不明白,还是论坛的上传大小设置太小了???
附件: 您所在的用户组无法下载或查看附件

作者: jfcat   发布时间: 2007-11-09

楼上的很强啊,每次都整理,辛苦了

作者: aphper   发布时间: 2007-11-12

看来有必要买本书来研究下

作者: herolee   发布时间: 2007-11-15

写起来不容易啊,看这一章觉得挺受用的
有机会准备买一下,好好看看!!!

作者: nywrb   发布时间: 2007-11-26

开始玩PHP的 CLI 模式. 有点问题. 在WIN下使用PHP的CLI模式时.运行脚本时必须添加 php scriptName.php 这样来运行. 只使用 scriptName.php 来运行DOS窗口只是会闪一下. 任何输出都没有. 不知道为什么. 我把php.exe的文件夹路径已经添加到了系统PATH.  并且在PHP脚本第一行已经指定了php.exe的执行路径.  "从命令行上读取参数如果想从命令行获取参数" 这个例子执行时把脚本名字当作了一个参数. 有提示信息. 我的PHP版本是5.2.5, OS 是XP SP2,
这本书大概翻了下. 内容涉及很广. 比一般的书要好点, 但是没有什么深入的东西. 都是属于介绍型的.
不知到WIN下弄PHP的CLI模式还需要什么其他的配置么?
修改一下程序代码:
复制PHP内容到剪贴板
PHP代码:
#!F:/Dev/Env/php-5.2.5/php.exe -q
<?php
define("BR", "\n");
echo "Test arg params number and values \n ";
echo "Params number is: " . $_SERVER["argc"] . BR ;
foreach($_SERVER["argv"] as $k => $v) {
  echo "The Param is: $k => $v".BR;
}
?>
然后在DOS下执行:
F:\Dev\cli>php arg.php Alway To Be Best
Test arg params number and values
Params number is: 5
The Param is: 0 => arg.php
The Param is: 1 => Alway
The Param is: 2 => To
The Param is: 3 => Be
The Param is: 4 => Best

很明显和作者写的有出入. 作者的代码执行后的结果绝对不是书本中显示的效果. 可以COPY输出信息看得出来结果不是原程序段的输出信息. 这点非常不好.  直接使用数组索引不存在警告信息比较恶心.
其实即时索引[0]被脚本文件名占用. 但是 argc 的值是多出一个的.
同样的, 脚本执行前还是要加php, 不知道作者是怎么设置的机器环境的.
还有一点, 中文都是乱码, 可能是与php.ini的配置文件有关系吧.


[ 本帖最后由 camgame 于 2008-2-13 11:02 编辑 ]

作者: camgame   发布时间: 2008-02-13

我找了很久,试试呀

作者: liu415   发布时间: 2008-05-24

热门下载

更多