专栏名称: 程序员大咖
为程序员提供最优质的博文、最精彩的讨论、最实用的开发资源;提供最新最全的编程学习资料:PHP、Objective-C、Java、Swift、C/C++函数库、.NET Framework类库、J2SE API等等。并不定期奉送各种福利。
目录
相关文章推荐
程序员小灰  ·  疯了!硅谷大佬预言:AI时代人类能活到150岁! ·  14 小时前  
程序猿  ·  阿里巴巴:裁减 24940 人! ·  昨天  
码农翻身  ·  漫画 | ... ·  23 小时前  
码农翻身  ·  程序员的红利彻底过去了。。。 ·  2 天前  
程序员小灰  ·  DeepSeek俱乐部,7000人了! ·  3 天前  
51好读  ›  专栏  ›  程序员大咖

从零开始创建一个 PHP 扩展

程序员大咖  · 公众号  · 程序员  · 2017-06-18 18:56

正文

本文主要讲解创建一个扩展的基本步骤都有哪些。示例中,我们将实现如下功能:


echo say();

?>


输出内容:


$ php ./test.php

$ hello word


在扩展中实现一个say方法,调用say方法后,输出 hello word。


第一步:生成代码


PHP为我们提供了生成基本代码的工具 ext_skel。这个工具在PHP源代码的./ext目录下。


$ cd php_src/ext/

$ ./ext_skel --extname=say


extname参数的值就是扩展名称。执行ext_skel命令后,这样在当前目录下会生成一个与扩展名一样的目录。


第二步,修改config.m4配置文件


config.m4的作用就是配合phpize工具生成configure文件。configure文件是用于环境检测的。检测扩展编译运行所需的环境是否满足。现在我们开始修改config.m4文件。


$ cd ./say

$ vim ./config.m4


打开,config.m4文件后,你会发现这样一段文字。


dnl If your extension references something external, use with:

dnl PHP_ARG_WITH(say, for say support,

dnl Make sure that the comment is aligned:

dnl [  --with-say             Include say support])

dnl Otherwise use enable:

dnl PHP_ARG_ENABLE(say, whether to enable say support,

dnl Make sure that the comment is aligned:

dnl [  --enable-say           Enable say support])


其中,dnl 是注释符号。上面的代码说,如果你所编写的扩展如果依赖其它的扩展或者lib库,需要去掉PHP_ARG_WITH相关代码的注释。否则,去掉 PHP_ARG_ENABLE 相关代码段的注释。我们编写的扩展不需要依赖其他的扩展和lib库。因此,我们去掉PHP_ARG_ENABLE前面的注释。去掉注释后的代码如下:


dnl If your extension references something external, use with:

dnl PHP_ARG_WITH(say, for say support,

dnl Make sure that the comment is aligned:

dnl [  --with-say             Include say support])

dnl Otherwise use enable:

PHP_ARG_ENABLE(say, whether to enable say support,

Make sure that the comment is aligned:

[  --enable-say           Enable say support])


第三步,代码实现


修改say.c文件。实现say方法。

找到PHP_FUNCTION(confirm_say_compiled),在其上面增加如下代码:


PHP_FUNCTION(say)

{

zend_string *strg;

strg = strpprintf(0, "hello word");

RETURN_STR(strg);

}


找到 PHP_FE(confirm_say_compiled, 在上面增加如下代码:


PHP_FE(say, NULL)


修改后的代码如下:


const zend_function_entry say_functions[] = {

PHP_FE(say, NULL)       /* For testing, remove later. */

PHP_FE(confirm_say_compiled,    NULL)       /* For testing, remove later. */

PHP_FE_END  /* Must be the last line in say_functions[] */

};

/* }}} */


第四步,编译安装


编译扩展的步骤如下:


$ phpize

$ ./configure

$ make && make install


修改php.ini文件,增加如下代码:


[say]

extension = say.so


然后执行,php -m 命令。在输出的内容中,你会看到say字样。








请到「今天看啥」查看全文