1、传递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的第一个参数。
2、编写一个具有交互式的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;
}
?>
3、在其他言语编写的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