phpize:使用phpize建立php扩展

  今天要讲是linux下php扩展入门篇

  下面我来讲讲如何作个php扩展

  首先要有个搭建好php环境

  我把php安装在了/usr/local/php当然也通过

  php个配置php.ini路径但是要注意了

  用这种思路方法安装php扩展不能实现

  我们在php安装以后/usr/local/php/bin目录

  找到这个文件phpize稍后我们将用到他

  他就是个shell脚本你可以用vi phpize来查看他内容

  但是你要注意了这个脚本不是在哪里都可以应用

  [root@ns root]# phpize

  Cannot find config.m4.

  Make sure that you run '/usr/local/bin/phpize' in the top level source directory of the module

  [root@ns root]# phpize

  Cannot find config.m4.

  Make sure that you run '/usr/local/bin/phpize' in the top level source directory of the module

  你会看到这两种结果实际上你查看了这个脚本

  很轻松就会发现是如何来处理

  你模扩展时候最好

  放在/usr/local/src/php-4.3.5/ext下

  来执行他你在这里也可以这样/usr/local/php/bin/phpize来执行也可以

  phpize来执行

  我们在/usr/local/src/php-4.3.5/ext下找到这个工具

  来建立个php扩展个框架

  [root@ns ext]#cd /usr/local/src/php-4.3.5/ext/

  [root@ns ext]# ./ext_skel --extname=jinzhesheng_module

  Creating directory jinzhesheng_module

  Creating basic files: config.m4 .cvsignore jinzhesheng_module.c php_jinzhesheng_module.h CREDITS EXPERIMENTAL tests/001.phpt jinzhesheng_module.php [done].

  To use your extension, you will have to execute the following steps:

  1. $ cd ..

  2. $ vi ext/jinzhesheng_module/config.m4

  3. $ ./buildconf

  4. $ ./configure --[with|enable]-jinzhesheng_module

  5. $ make

  6. $ ./php -f ext/jinzhesheng_module/jinzhesheng_module.php

  7. $ vi ext/jinzhesheng_module/jinzhesheng_module.c

  8. $ make

  执行了这个步骤以后你会看到这样结果

  Repeat steps 3-6 until you are satisfied with ext/jinzhesheng_module/config.m4 and

  step 6 confirms that your module is compiled o PHP. Then, start writing

  code and repeat the last two steps as often as necessary.

  这样以后我们会在这个目录下生成个目录叫jinzhesheng_module

  进入这里面我们看看

  [root@ns ext]# cd jinzhesheng_module/

  [root@ns jinzhesheng_module]# ls

  config.m4 EXPERIMENTAL     jinzhesheng_module.php  tests

  CREDITS  jinzhesheng_module.c php_jinzhesheng_module.h

  然后我们要修改文件顺序是

  configue.m4

  jinzhesheng_module.c

  php_jinzhesheng_module.h

  使用文本编辑器打开config.m4文件文件内容大致如下:

  dnl $Id$d

  dnl config.m4 for extension my_module

  dnl don't forget to call PHP_EXTENSION(my_module)

  dnl Comments in this file start with the 'dnl'.

  dnl Remove where necessary. This file will not work

  dnl without editing.

  dnl If your extension references something external, use with:

  dnl PHP_ARG_WITH(my_module, for my_module support,

  dnl Make sure that the comment is aligned:

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

  dnl Otherwise use enable:

  dnl PHP_ARG_ENABLE(my_module, whether to enable my_module support,

  dnl Make sure that the comment is aligned:

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

   test "$PHP_MY_MODULE" != "no"; then

  dnl If you will not be testing anything external, like existence of

  dnl headers, libraries or functions in them, just uncomment the

  dnl following line and you are ready to go.

  dnl Write more examples of tests here...

  PHP_EXTENSION(my_module, $ext_shared)

  Fi

  根据你自己选择将

  dnl PHP_ARG_WITH(my_module, for my_module support,

  dnl Make sure that the comment is aligned:

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

  修改成

  PHP_ARG_WITH(my_module, for my_module support,

  Make sure that the comment is aligned:

  [ --with-my_module       Include my_module support])

  或者将

  dnl PHP_ARG_ENABLE(my_module, whether to enable my_module support,

  dnl Make sure that the comment is aligned:

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

  修改成

  PHP_ARG_ENABLE(my_module, whether to enable my_module support,

  Make sure that the comment is aligned:

  [ --enable-my_module      Enable my_module support])

  我这里用了后者

  然后保存退出

  然后在编辑

  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_prf("hello worldn");
}


  保存文件退出

  然后我们就可以在这个目录下使用上面命令了

  /usr/local/php/bin/phpize

  执行以后会看到下面

  [root@ns jinzhesheng_module]# /usr/local/php/bin/phpize

  Configuring for:

  PHP Api Version:     20020918

  Zend Module Api No:   20020429

  Zend Extension Api No:  20050606

  [root@ns jinzhesheng_module]#

  然后执行./configure --enable-jinzhesheng_module --with-apxs=/usr/local/apache/bin/apxs --with-php-config=/usr/local/php/bin/php-config

  我们在安装以后phpbin目录下可以找到这个文件



  php-config 和phpize

  这步骤定要注意你apacheapxs放在哪里了

  然后执行make

  你会看到出现了你重新定义了我们前面

  这个你在回头改下这个文件把原来删除掉在生成文件里面会有同样

  你在加入你代码

  就可以通过了

  这个时候会在当前目录下生成个目录叫modules他下面就放着你要

  jinzhesheng_module.so文件

  cp modules/jinzhesheng_module.so /usr/local/php/ext/

  这里需要你先设置你php扩展目录

  在php.ini里面

  通过extension_dir

  最后不是你在php.ini文件中打开这个扩展

  extension=jinzhesheng_module.so

  然后

  重新起动apache

  用phpinfo来察看下ok了



Tags:  扩展名php windowsphp扩展 php扩展 phpize

延伸阅读

最新评论

发表评论