PHP 执行档的安装
一般 PHP 作为网页处理语言都是要编译成 Apache 的模块﹐这里当然不么做﹐也因此编译起来很简单﹐只要以 root 的身分进行如下动作 :
解开 php-3.0.xx.tar.gz
cd php
configure
make
编译完之后,在 php 目录下有一个可执行档,档名为 php,将它 copy 到 /usr/local/bin 下即可,注意,如果档案太大,可以使用 strip 指令将 php 的方式将不必要的信息去除,这样档案就会小得多了。
第一个程序
开始撰写我们的第一个 PHP Shell Script 程序﹐这个例子印出 "Hello world !":
- #!/usr/local/bin/php -q
- <?
- echo "Hello, world !";
- ?>
注意到 PHP 原本是应用在网页应用的,因此它内定会送出 HTML 的 HEADER,但是在此我们是要将 PHP 用作 Shell Script,"-q" 就是表示不要送出 HEADER 的意思,你可以试试看不加上 -q 的显示结果。
在这个例子中,/usr/local/bin/php 是表示要执行 /usr/local/bin/ 下的 PHP,因为我们刚才将它装在该处,echo 指令将 "Hello, world !" 印出,其中的 "" 字符是换行字符。
注意到在将这个程序存成档案后,须将其 chmod 成为可执行属性(chmod +x 文件名),然后才能执行喔。
进阶使用 I
有时候我们需要在程序执行时,送进一些参数,比如说 ls 这个指令,后面可以加上 -l 参数,PHP Shell Script 一样也有支持这样的用法,有两个特殊的变量:$argc 记录着后面送入参数的个数,$argv[] 数组参数存着的则是参数的内容,比如说我现在要设计一个算两个数字总和的程序:
- #!/usr/local/bin/php -q
- <?
- $sum=0;
- $sum=$sum+$argv[1]+$argv[2];
- echo $sum;
- ?>
假设将此程序命名为 sum.php3,则执行 sum.php3 1 2 按下 enter 则会印出 3。
如果要算出不特定个数的参数和,那么就得要用到 $argc 这个特殊变量了:
- #!/usr/local/bin/php -q
- <?
- $sum=0;
- for ($t=1;$t<=$argc;$t++)
- $sum=$sum+$argv[$t];
- echo $sum;
- ?>
假设将此程序命名为 bigsum.php3,则执行 bigsum.php3 1 2 3 4 5 按下 enter 则会印出 15,执行 bigsum.php3 1 2 3 4 5 6 按下 enter 则会印出 21。
有时候我们需要在程序执行中输入资料,但是 PHP 原本就是用于网页设计,而网页上的资料输入自然都是用 FORM 的方式来输入,所以这将 PHP 作为 Shell Script 时问题就来了,好在 PHP 有提供了开文件功能﹐而在 Linux/Uinx 之下,输入(input)这件事原本就可以用开档的方式来完成,我们要开启的是 /dev/stdin 这个设备档(stdin 是表示 standard input 的意思),程序如下:
- #!/usr/local/bin/php -q
- <?
- $fp=fopen("/dev/stdin","r");
- $inputstr=fgets($fp,100);
- fclose($fp);
- echo "n----------------------n";
- echo $inputstr;
- ?>
其中的 fgets($fp,100) 是指从 $fp 这个档案(也就是 "/dev/stdin")中读取出 100 个 byte 的资料,程序执行到这行便会停下来等待我们的输入,当我们输入完按下 enter 之后,程序就会将刚才我们输入的资料给印出来了。
进阶使用 II
虽然已经可以处理输入,但是这样的功能显然还是太简单,无法应付更大的应用,比如说我需要一个功能是将一串资料流(data stream)中的 HTML 给去除,这时便需要完整地处理输出输入转向的能力,我们可以先设计程序如下:
- #!/usr/local/bin/php -q
- <?
- $fp=fopen("/dev/stdin","r");
- while(!feof($fp)) {
- $c=fgetc($fp);
- $inputstr=$inputstr.$c;
- };
- fclose($fp);
- echo $inputstr;
- ?>
假设将此程序命名为 filt.php3,如果你直接执行这个程序,它会一直等待你输入,直到你按下 Ctrl+D 后才会将你的输入资料给印出,我们可以这么执行它:
more filt.php3 | filt.php3
这样的做法是将 filt.php3 这个程序用 more 给秀出并转向给 filt.php3 这个程序,filt.php3 会不断接受资料(事实上就是 filt.php3 程序代码本身),最后将其印出。
我们可以在其中加上过滤 HTML 的功能:
- #!/usr/local/bin/php -q
- <?
- $fp=fopen("/dev/stdin","r");
- while(!feof($fp)) {
- $c=fgetc($fp);
- $inputstr=$inputstr.$c;
- };
- fclose($fp);
- $inputstr=ereg_replace("<([^<>]*)>","",$inputstr);
- echo $inputstr;
- ?>
假设将此程序命名为 filt2.php3,如此一来便完成了过滤功能,不信请拿个 HTML 档来试试看:
more xxx.html | filt2.php3
你便会看到删除了 HTML TAG 的文件了. |