一、傳遞Shell指令碼運行參數給PHP:
作為一個Shell指令碼,經常會在運行程式時候加入一些參數,PHP作為Shell指令碼時有一個內嵌的數組“$argv”,使用“$argv”數組可以很方便的讀取Shell指令碼運行時候的參數(“$argv[1]”對應的是第一個參數,“$argv[2]”對應的是第二個參數,依此類推)。比如下面這個程式:
#!/usr/local/bin/php -q
<?php
$first_name = $argv[1];
$last_name = $argv[2];
printf("Hello, %s %s! How are you today?\n", $first_name, $last_name);
?>
上面的代碼在啟動並執行時候需要兩個參數,分別是姓和名,比如這樣子運行:
[dbrogdon@artemis dbrogdon]$ scriptname.ph Darrell Brogdon
Shell指令碼在顯示器上面會輸出:
Hello, Darrell Brogdon! How are you today?
[dbrogdon@artemis dbrogdon]$
在PHP作為動態網頁編寫語言的時候也含有“$argv”這個數組,不過和這裡有一些不同:當PHP作為Shell指令碼語言的時候“$argv[0]”對應的是指令碼的檔案名稱,而當用於動態網頁編寫的時候,“$argv[1]”對應的是QueryString的第一個參數。
二、編寫一個具有互動Shell指令碼:
如果一個Shell指令碼僅僅是自己運行,失去了互動性,那麼也沒有什麼意思了。當PHP用於Shell指令碼的編寫的時候,怎麼讀取使用者輸入的資訊呢?很不幸的是PHP自身沒有讀取使用者輸入資訊的函數或者方法,但是我們可以效仿其他語言編寫一個讀取使用者輸入資訊的函數“read”:
<?php
function read() {
$fp = fopen('/dev/stdin', 'r');
$input = fgets($fp, 255);
fclose($fp);
return $input;
}
?>
需要注意的是上面這個函數只能用於Unix系統(其他系統需要作相應的改變)。上面的函數會開啟一個檔案指標,然後讀取一個不超過255位元組的行(就是fgets的作用),然後會關閉檔案指標,返回讀取的資訊。
現在我們可以使用函數“read”將我們前面編寫的程式1修改一下,使他更加具有“互動性”了:
#!/usr/local/bin/php -q
<?php
function read() {
$fp = fopen('/dev/stdin', 'r');
$input = fgets($fp, 255);
fclose($fp);
return $input;
}
print("What is your first name? ");
$first_name = read();
print("What is your last name? ");
$last_name = read();
print("\nHello, $first_name $last_name! Nice to meet you!\n");
?>
將上面的程式儲存下來,運行一下,你可能會看到一件預料之外的事情:最後一行的輸入變成了三行!這是因為“read”函數返回的資訊還包括了使用者每一行的結尾分行符號“\n”,保留到了姓和名中,要去掉結尾的分行符號,需要把“read”函數修改一下:
<?php
function read() {
$fp = fopen('/dev/stdin', 'r');
$input = fgets($fp, 255);
fclose($fp);
$input = chop($input); // 去除尾部空白
return $input;
}
?>
三、在其他語言編寫的Shell指令碼中包含PHP編寫的Shell指令碼:
有時候我們可能需要在其他語言編寫的Shell指令碼中包含PHP編寫的Shell指令碼。其實非常簡單,下面是一個簡單的例子:
#!/bin/bash
echo This is the Bash section of the code.
/usr/local/bin/php -q << EOF
<?php
print("This is the PHP section of the code\n");
?>
EOF
其實就是調用PHP來解析下面的代碼,然後輸出;那麼,再試試下面的代碼:
#!/bin/bash
echo This is the Bash section of the code.
/usr/local/bin/php -q << EOF
<?php
$myVar = 'PHP';
print("This is the $myVar section of the code\n");
?>
EOF
可以看出兩次的代碼唯一的不同就是第二次使用了一個變數“$myVar”,試試運行,PHP竟然給出出錯的資訊:“Parse error: parse error in - on line 2”!這是因為Bash中的變數也是“$myVar”,而Bash解析器先將變數給替換掉了,要想解決這個問題,你需要在每個PHP的變數前面加上“\”轉義符,那麼剛才的代碼修改如下:
#!/bin/bash
echo This is the Bash section of the code.
/usr/local/bin/php -q << EOF
<?php
\$myVar = 'PHP';
print("This is the \$myVar section of the code\n");
?>
EOF