system函数
说明:执行外部程序并显示输出资料.
语法:string
system(string
command,
int
[return_var]);
返回值:
字符串
详细介绍:
本函数就像是
C
语中的函数
system(),用来执行指令,并输出结果.若是
return_var
参数存在,则执行
command
之后的状态会填入
中.同样值得注意的是若需要处理用户输入的资料,而又要防止用户耍花招破解系统,则可以使用
EscapeShellCmd().若
PHP
以模块式的执行,本函数会在每一行输出后自动更新
Web
服务器的输出缓冲暂存区.若需要完整的返回字符串,且不想经过不必要的其它中间的输出界面,可以使用
PassThru().
实例代码:
复制代码
代码如下:
php
$last_line
=
system('ls',
$retval);
echo
'Last
line
of
the
output:
'
.
$last_line;
'hr
/Return
value:
$retval;
exec函数
说明:执行外部程序.
exec(string
string
[array],
本函数执行输入
的外部程序或外部指令.它的返回字符串只是外部程序执行后返回的最后一行;若需要完整的返回字符串,可以使用
PassThru()
这个函数.
要是参数
array
存在,command
会将
加到参数中执行,若不欲
被处理,可以在执行
exec()
之前呼叫
unset().若是
跟
二个参数都存在,则执行
中.
值得注意的是若需要处理使用者输入的资料,而又要防止使用者耍花招破解系统,则可以使用
EscapeShellCmd().
exec('whoami');
popen函数
说明:打开文件.
语法:int
popen(string
mode);
整数
本函数执行指令开档,而该文件是用管道方式处理的文件.用本函数打开的文件只能是单向的
(只能读或只能写),而且一定要用
pclose()
关闭.在文件操作上可使用
fgets()、fgetss()
与
fputs().若是开档发生错误,返回
false
值.
$fp
popen("/bin/ls","r"
);
PHP监控linux服务器负载
在实际项目的应用中,我们由于各种条件的现实,利用PHP来实现服务器负载监控将是一种更为灵活的方式.
由于Web
Server以及PHP的实现方式所限,我们在现实环境中很难利用PHP去调用一些Linux中需要root权限才能执行的程序,对此,我从网上找到另外一种方式来绕开这个限制.首先先写个c程序中转调用系统命令,然后用PHP去执行此c程序.
c程序
首先写个c文件,比如/usr/local/ismole/w.c
#includestdio.h
#includestdlib.h
#includesystypes.h
#includeunistd.h
main()
{
uid_t
uid
,euid;
//note
获得当前的uid
getuid();
获得当前euid
euid
geteuid();
交换这两个id
if(setreuid(euid,
uid))
perror("setreuid");
执行将要执行linux系统命令
system("/usr/bin/w");
return0;
}
编译该文件gcc
-o
w
-Wall
w.c,这时会在当前目录下生成程序w.改变此程序的属主chmod
u+s
./w.
PHP执行
文件内容如下,放在web目录下,访问就会输出当前的服务器负载情况.
/*
More
Original
Framwork
Copyright
(c)
-
IsMole
Inc.
$Id:
serverMonitor.php
kimi
$
*/
key的验证过程
if($key
!=
$authkey)
//
exit('key
error);
exec('/usr/local/ismole/w',
$returnArray
explode("load
average:
",
$retval[0]);
$returnString
$returnArray[1];
$returnString;
按照上面的实例,我们可以用PHP来做任何我们想执行的Linux系统命令,SVN更新,服务器监控,备份,恢复,日常维护等等.
linux下输入visudo
然后我们在最后追加
www ALL=NOPASSWD:/bin/sh
然后
php执行exec("/usr/bin/sudo /bin/sh whoami")
首先先要给大家介绍PHP执行linux系统命令的几个基本函数.
语法:string system(string command, int [return_var]);
返回值: 字符串
本函数就像是 C 语中的函数 system(),用来执行指令,并输出结果.若是 return_var 参数存在,则执行 command 之后的状态会填入 return_var 中.同样值得注意的是若需要处理用户输入的资料,而又要防止用户耍花招破解系统,则可以使用 EscapeShellCmd().若 PHP 以模块式的执行,本函数会在每一行输出后自动更新 Web 服务器的输出缓冲暂存区.若需要完整的返回字符串,且不想经过不必要的其它中间的输出界面,可以使用 PassThru().
$last_line = system('ls', $retval);
echo 'Last line of the output: ' . $last_line;
echo 'hr/Return value: ' . $retval;
语法:string exec(string command, string [array], int [return_var]);
本函数执行输入 command 的外部程序或外部指令.它的返回字符串只是外部程序执行后返回的最后一行;若需要完整的返回字符串,可以使用 PassThru() 这个函数.
要是参数 array 存在,command 会将 array 加到参数中执行,若不欲 array 被处理,可以在执行 exec() 之前呼叫 unset().若是 return_var 跟 array 二个参数都存在,则执行 command 之后的状态会填入 return_var 中.
值得注意的是若需要处理使用者输入的资料,而又要防止使用者耍花招破解系统,则可以使用 EscapeShellCmd().
echo exec('whoami');
语法:int popen(string command, string mode);
返回值: 整数
本函数执行指令开档,而该文件是用管道方式处理的文件.用本函数打开的文件只能是单向的 (只能读或只能写),而且一定要用 pclose() 关闭.在文件操作上可使用 fgets()、fgetss() 与 fputs().若是开档发生错误,返回 false 值.
$fp = popen( "/bin/ls", "r" );
通过上述函数,PHP可以执行linux系统的shell命令.
自己编写shell脚本. 然后用exec("1.sh")执行. 具体脚本可以参考XenServer
以上就是土嘎嘎小编为大家整理的怎么在php后whoami相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!