电脑技术学习

编写自己的php扩展函数

dn001

;
一般我会选择后者,然后保存退出。如果你对vi文本编辑器的操作有困难的话,请参考相应的说明文章,这里就不再详细描述了。
Vi my_module.c
将文件其中的下列代码进行修改
/* Every user visible function must have an entry in my_module_functions[].
*/
function_entry my_module_functions[] = {
;;;;PHP_FE(say_hello,;;;NULL) /*ß添加着一行代码*/
;;;;PHP_FE(confirm_my_module_compiled,;;NULL) /* For testing, remove later. */
;;;;{NULL, NULL, NULL};;/* Must be the last line in my_module_functions[] */
};
;
在文件的最后添加下列代码
PHP_FUNCTION(say_hello)
{
;;;;zend_printf("hello world\n");
}
保存文件退出
;
vi php_my_module.h
在文件中PHP_FUNCTION(confirm_my_module_compiled);一行前面添加下面的代码
PHP_FUNCTION(say_hello);
保存文件退出
;
退回到php的根目录下,执行下面的命令
./buildconf
./configure --enable-my_module
make
;
如果一切顺利的话,我们现在已经将扩展模块my_module编译到php里面了。我们编写下面的代码进行测试
<?
;;;Say_hello();
?>
保存文件为say_hello.php
在php的根目录下运行
./php –q say_hello.php
正常情况下会显示
hello world
表示我们的第一个扩展正常的运行了!
;
解释一下上面做的操作,ext_skel生成一些框下文件,我们需要修改以下文件
my_module.c 扩展模块的主程序
php_my_module.h扩展模块的头文件
config.m4 配置文件
;
主程序中描述了php扩展模块的声明,模块中含有多少个函数,各个函数的作用,在phpinfo函数中显示什么内容,模块初始化做些什么,结束做些什么都会在这个文件里进行描述。我们在上面只是添加了一个函数say_hello,并且描述了say_hello函数的具体内容,调用zend_printf系统函数在php中打印字符串。
;
在对应的头文件中声明了say_hello这个函数,从而完成了我们预期的功能。下面我们会编写一个更复杂的扩展,创造一个带参数的php扩展函数,根据给入的参数,显示hello world, xxxx。Xxxx代表输入的字符串内容,例如我的名字yorgo。
;
Vi my_module.c
修改最后的say_hello函数内容如下:
PHP_FUNCTION(say_hello)
{
;;;;zval **yourname;
;
;;;;if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &yourname) == FAILURE)
;;;;{
;;;;WRONG_PARAM_COUNT;
;;;;}
;
;;;;zend_printf("hello world, %s\n", Z_STRVAL_PP(yourname));
}
存盘退出。
退回php的根目录,运行
make
修改say_hello.php为
<?
;;;Say_hello(“yorgo);
?>
保存退出后运行
./php –q say_hello.php
得出结果
hello world, yorgo
表示我们这次的修改也成功了,可以改变say_hello中的参数,看看动态的效果。
这里主要解释上面修改的函数内容,由于say_hello函数需要有参数引入,所以在my_module.c中的say_hello函数主要在进行参数的处理,将php中引用say_hello时所填写的参数内容正确的传递到my_module.c中的say_hello处理函数中。为此,程序中添加了这么几行。
zval **yourname;
if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &yourname) == FAILURE)
{
WRONG_PARAM_COUNT;
}
zend_printf("hello world, %s\n", Z_STRVAL_PP(yourname));
;
代码解释如下:
zval **yourname;
初始化一个参数的指针
ZEND_NUM_ARGS()
得到传递过来得参数数量,并且判断如果不为1的时候表示有问题,报错。
zend_get_parameters_ex(1, &yourname)
将刚刚初始化的指针指向传递过来的参数,如果不成功则报错。
Z_STRVAL_PP(yourname)
处理指针指向的参数并获得实际存储的值。

标签: 函数