本篇内容主要讲解“PHP怎么自定义扩展”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP怎么自定义扩展”吧!
利用源码工具自动生成扩展目录结构
先进入php源码ext目录下执行下面命令
/www/test/php/php/bin/php ext_skel.php --ext helloworldcd helloworld
修改config.m4
配置文件,就是现在写的扩展是否用到外部依赖,就配置--with-hello选项,否则配置--enable-hello
选项,按照自己的需求把注释去掉
dnl If your extension references something external, use 'with': PHP_ARG_WITH([helloworld], [for helloworld support], [AS_HELP_STRING([--with-helloworld], [Include helloworld support])])dnl Otherwise use 'enable':
扩展功能书写
然后vim helloworld.c
进行扩展功能代码书写
先看下模块结构定义
zend_module_entry helloworld_module_entry = { STANDARD_MODULE_HEADER, "helloworld", helloworld_functions, PHP_MINIT(helloworld), NULL, PHP_RINIT(helloworld), NULL, PHP_MINFO(helloworld), PHP_HELLOWORLD_VERSION, PHP_MODULE_GLOBALS(pib), NULL, NULL, NULL, STANDARD_MODULE_PROPERTIES_EX};
功能函数名字集合
static const zend_function_entry helloworld_functions[] = { PHP_FE(helloworld_test1, arginfo_helloworld_test1) PHP_FE(helloworld_test2, arginfo_helloworld_test2) PHP_FE_END};
真正的功能函数代码
PHP_FUNCTION(helloworld_test2){ int argc = ZEND_NUM_ARGS(); char *messages = NULL; size_t messages_len = 0; char *context = NULL; size_t context_len = 0; zend_string *retval; ZEND_PARSE_PARAMETERS_START(0, 2) Z_PARAM_OPTIONAL Z_PARAM_STRING(messages, messages_len) Z_PARAM_STRING(context, context_len) ZEND_PARSE_PARAMETERS_END(); retval = strpprintf(0, "Hello %s test %s", messages, context); RETURN_STR(retval);}
函数参数定义
ZEND_BEGIN_ARG_INFO(arginfo_helloworld_test2, 0) ZEND_ARG_INFO(0, str)ZEND_END_ARG_INFO()
编译安装
/www/test/php/php/bin/phpize./configure --with-php-config=/www/test/php/php/bin/php-configmake && make install
现在PHP的扩展目录中已经有了helloworld.so
这个文件,在php.ini
中添加上扩展的配置
extension = helloworld.so
然后就可以测试自己写的函数了helloworld_test2()
到此,相信大家对“PHP怎么自定义扩展”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!