
说明:执行外部程序并显示输出资料。
语法:string
system(string
command,
int
[return_var])
返回值:
字符串
详细介绍:
本函数就像是
C
语中的函数
system(),用来执行指令,并输出结果。若是
return_var
参数存在,则执行
command
之后的状态会填入
return_var
中。同样值得注意的是若需要处理用户输入的资料,而又要防止用户耍花招破解系统,则可以使用
EscapeShellCmd()。若
PHP
以模块式的执行,本函数会在每一行输出后自动更新
Web
服务器的输出缓冲暂存区。若需要完老并型整蔽槐的返回字符串,且不想经过不必要的其它中间的输出界面,可以使用
PassThru()。
实例代码:
复制代码
代码如下:
<
?php
$last_line
=
system('ls',
$retval)
echo
'Last
line
of
the
output:
'
.
$last_line
echo
'<hr
/>Return
value:
'
.
$retval
?>
exec函数
说明:执行外部程序。
语法:string
exec(string
command,
string
[array],
int
[return_var])
返回值:
字符串
详细介绍:
本函数执行输入
command
的外部程序或外部指令。它的返回字符串只是外部程序执行后返回的最后一行;若需要完整的返回字符串,可以使用
PassThru()
这个函数。
要是参数
array
存在,command
会将
array
加到参数中执行,若不欲
array
被处理,可以在执行
exec()
之前呼叫
unset()。若是
return_var
跟
array
二个参数都存在,则执行
command
之后的状态会填入
return_var
中。
值得注意的是若需要处理使用者输入的资料,而又要防止使用者耍花招破解系统,则可以使用
EscapeShellCmd()。
实例代码:
复制代码
代码如下:
<
?php
echo
exec('whoami')
?>
popen函数
说明:打开文件。
语法:int
popen(string
command,
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
复制代码
代码如下:
#include<stdio.h>
#include<stdlib.h>
#include<systypes.h>
#include<unistd.h>
int
main()
{
uid_t
uid
,euid
//note
获得当前的uid
uid
=
getuid()
//note
获得当前euid
euid
=
geteuid()
//note
交换这两个id
if(setreuid(euid,
uid))
perror("setreuid")
//note
执行将要执行linux系统命令
system("/usr/bin/w")
return0
}
编译该文件gcc
-o
w
-Wall
w.c,这时会在当前目录下生成程序w。改变此程序的属主chmod
u+s
./w。
PHP执行
文件内容如下,放在web目录下,访问就会输出当前的服务器负载情况。
复制代码
代码如下:
<?php
/*
More
&
Original
PHP
Framwork
Copyright
(c)
2007
-
2008
IsMole
Inc.
$Id:
serverMonitor.php
408
2008-12-02
08:07:40Z
kimi
$
*/
//note
key的验证过程
if($key
!=
$authkey)
{
//
exit('key
error)
}
$last_line
=
exec('/usr/local/ismole/w',
$retval)
$returnArray
=
explode("load
average:
",
$retval[0])
$returnString
=
$returnArray[1]
echo
$returnString
按照上面的实例,我们可以用PHP来做任何我们想执行的Linux系统命令,SVN更新,服务器监控,备份,恢复,日常维护等等。
1:预定义
在home目录,也可以其他任意目录,写一个文件,例如caleng_module.def
内容是你希望定义的函数名以及参数:
int a(int x,int y)
string b(string str,int n)
2:到php源码目录的ext目录
#cd /usr/local/php-5.4.0/ext/
执行命令,生成对应扩展目录
#./ext_skel --extname=caleng_module --proto=/home/hm/caleng_module.def
3:修改config.m4
去掉dnl的注释
PHP_ARG_ENABLE(caleng_module, whether to enable caleng_module support,
Make sure that the comment is aligned:
[ --enable-caleng_module Enable caleng_module support])
4:修改caleng_module.c
代码如下:
/* {{{ proto int a(int x, int y)
*/
PHP_FUNCTION(a)
{
int argc = ZEND_NUM_ARGS()
int x
int y
int z
if (zend_parse_parameters(argc TSRMLS_CC, "ll", &x, &y) == FAILURE)
return
z=x+y
RETURN_LONG(z)
}
/* }}} */
/* {{{ proto string b(string str, int n)
*/
PHP_FUNCTION(b)
{
char *str = NULL
int argc = ZEND_NUM_ARGS()
int str_len
山圆 long n
char *result
char *ptr
int result_length
if (zend_parse_parameters(argc TSRMLS_CC, "sl", &str, &str_len, &n) == FAILURE)
return
result_length = str_len * n
result = (char *) emalloc(result_length + 1)
ptr = result
while (n--) {
memcpy(ptr, str, str_len)
ptr += str_len
}
*ptr = '\0'
RETURN_STRINGL(result, result_length, 0)
}
/* }}} */
5:生成扩展库
#cd ./caleng_module
#/usr/local/php/bin/phpize
#./configure --with-php-config=/usr/local/php/bin/php-config
#make
#make install
6:到php的对应extensions目录
如上图所示
#cd /usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/
改目录下族亮有生成的caleng_module.so文件
7:修改php.ini
php.ini如果找不到可以从phpinfo()打出的信息看到
#cd /usr/local/php/lib/
php.ini增加扩展信息
extension=caleng_module.so
8:重启Apache
# /usr/local/apache2/bin/apachectl restart
9:检查加载
/usr/local/php/bin/php -m
10:PHP调用
代码如下:
echo a(1,2)
输出 3 就说明成功了!
下面是原文
Linux下用C开发PHP扩展
一、首先下载PHP源码包,假设源码包目录为:/software/php-5.2.13
一、首先下载PHP源码包,假设兆唯宽源码包目录为:/software/php-5.2.13
#>cd /software/php-5.2.13/ext
二、假设我们要开发一个名为caleng_module的扩展,该扩展包含两个函数:a--处理两个整型相加和b-处理字符串重复输出;
1、首先编写一个函数定义文件,该文件编写函数原型后缀为def,假设为:caleng_module.def
int a(int x, int y)
string b(string str, int n)
2、通过扩展骨架生成器,将在ext目录下自动建立扩展目录caleng_module
#>./ext_skel --extname=caleng_module --proto=caleng_module.def
3、修改配置文件: #>vim /software/php-5.2.13/ext/caleng_module/config.m4,将如下行的注释标签"dnl"去掉,修改后如下所示:
PHP_ARG_ENABLE(myfunctions, whether to enable myfunctions support,
Make sure that the comment is aligned:
[ --enable-myfunctions Enable myfunctions support])
4、完善函数a和b的功能: #>vim /software/php-5.2.13/ext/caleng_module/caleng_module.c
PHP_FUNCTION(a)
{
int x, y, z
int argc = ZEND_NUM_ARGS()
if (zend_parse_parameters(argc TSRMLS_CC, "ll", &x, &y) == FAILURE)
return
z = x + y
RETURN_LONG(z)
}
PHP_FUNCTION(b)
{
char *str = NULL
int argc = ZEND_NUM_ARGS()
int str_len
long n
char *result
char *ptr
int result_length
if (zend_parse_parameters(argc TSRMLS_CC, "sl", &str, &str_len, &n) == FAILURE)
return
result_length = str_len * n
result = (char *) emalloc(result_length + 1)
ptr = result
while (n--) {
memcpy(ptr, str, str_len)
ptr += str_len
}
*ptr = '\0'
RETURN_STRINGL(result, result_length, 0)
}
三、编译安装,假设php的安装目录为:/usr/localhost/webserver/php
#>cd /software/php-5.2.13/ext/caleng_module
#>/usr/localhost/webserver/php/bin/phpize
#>./configure --with-php-config=/usr/localhost/webserver/php/bin/php-config
#>make
#>make install
现在将在/usr/local/webserver/php/lib/php/extensions/no-debug-non-zts-20060613目录下生成caleng_module.so文件
在php.ini配置文件中加入: extension=caleng_module.so.
可以我写过一个调用SAP BO的COM,要调用必须先安装好COM组件的,在注册表查出组件名码戚字(如果你不清闹旦楚组件名字的话)我把我写过的函数给你看看/**
* 加载COM组件
*/
private function createCompanyObject() {
$company = false
try {
$company = new COM("SapBobsCom.Company"液模扰)//这样就可以获取COM组件了
} catch(Exception $e) {
$this->errorMsg = $e->getMessage()
}
return $company
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)