探讨:如何编写PHP扩展
本篇文章是对如何编写PHP扩展进行了详细的分析介绍, 需要的朋友参考下
用C/C++扩展PHP的优缺点:
优点:
效率,还是效率
减少PHP脚本的复杂度, 极端情况下, 你只需要在PHP脚本中,简单的调用一个扩展实现的函数,然后你所有的功能都就被扩展实现了
而缺点也是显而易见的:
开发复杂
可维护性降低
开发周期变长, 最简单的一个例子,当你用PHP脚本的时候, 如果你发现某个判断条件出错,你只要修改了这一行,保存,那么就立刻能见效。 而如果是在C/C++编写的PHP扩展中, 那你可需要,修改源码,重新编译,然后重新load进PHP, 然后重启Apache,才能见效。
如果你熟悉C,那么编写一个PHP扩展,并不是什么非常难的事情。 PHP本身就提供了一个框架,来简化你的开发。
最简单的方式来开始一个PHP扩展的开发,是使用PHP提供的扩展框架wizard ext_skel, 它会生成一个PHP扩展所必须的最基本的代码, 要使用它,首先你要下载PHP的源码,或者开发包, 进入PHP源码的ext目录, 就会发现这个工具。
生成一个扩展:
./ext_skel --extname=myext
进入/myext,选择扩展类型:
vi config.m4
下面两种类型选一个就行了:
//(依赖外部库) dnl PHP_ARG_WITH(myext, for myext support, dnl Make sure that the comment is aligned: dnl [ --with-myext Include myext support]) //去掉dnl PHP_ARG_WITH(myext, for myext support, Make sure that the comment is aligned: [ --with-myext Include myext support])//或者将 //(不依赖外部库) dnl PHP_ARG_ENABLE(myext, whether to enable myext support,dnl Make sure that the comment is aligned:dnl [ --enable-myext Enable myext support])//去掉dnl 修改头文件php_myext.h: //PHP_FUNCTION(confirm_myext_compiled); /* For testing, remove later. */ //修改为 PHP_FUNCTION(myext); /* For testing, remove later. */ 修改myext.c: //将 //zend_function_entry myext_functions[] = { // PHP_FE(confirm_myext_compiled, NULL) /* For testing, remove later. */ // {NULL, NULL, NULL} /* Must be the last line in myext_functions[] */ //}; //修改为 zend_function_entry myext_functions[] = { PHP_FE(myext, NULL) /* For testing, remove later. */ {NULL, NULL, NULL} /* Must be the last line in myext_functions[] */ }; //在文件底部添加自己的函数 PHP_FUNCTION(myext) { zend_printf("Hello World!\n"); } 安装自己的php扩展myext: /usr/local/php/bin/phpize ./configure --with-php-config=/usr/local/php/bin/php-config make make install
修改php.ini,添加:
extension = "myext.so"
重启web服务器,查看phpinfo,即可看到自己的扩展:
新建测试php文件:
<?php
myext();
执行此文件,即可看到再熟悉不过的“Hello World!”。