`

使用phpize建立php扩展 Cannot find config.m4.

    博客分类:
  • php
 
阅读更多
原文地址:http://lxsym.blog.51cto.com/1364623/293862/





下面我来讲讲如何作一个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=sdomain
  Creating directory sdomain
  Creating basic files: config.m4 .cvsignore sdomain.c php_sdomain.h CREDITS EXPERIMENTAL tests/001.phpt sdomain.php [done].
To use your new extension, you will have to execute the following steps:
  1. $ cd ..
  2. $ vi ext/sdomain/config.m4
  3. $ ./buildconf
  4. $ ./configure --[with|enable]-sdomain
  5. $ make
  6. $ ./php -f ext/sdomain/sdomain.php
  7. $ vi ext/sdomain/sdomain.c
  8. $ make
  执行了这个步骤以后你会看到这样的结果
  Repeat steps 3-6 until you are satisfied with ext/sdomain/config.m4 and
  step 6 confirms that your module is compiled into PHP. Then, start writing
  code and repeat the last two steps as often as necessary.
  这样以后我们会在这个目录下生成一个目录叫sdomain
  进入这里面我们看看
  [root@ns ext]# cd sdomain/
  [root@ns sdomain]# ls
  config.m4 EXPERIMENTAL     sdomain.php  tests
  CREDITS  sdomain.c php_sdomain.h
  然后我们要修改文件顺序是
  configue.m4
  sdomain.c
  php_sdomain.h
  使用文本编辑器打开config.m4文件,文件内容大致如下:
  dnl $Id$d
  dnl config.m4 for extension my_module
  dnl dont forget to call PHP_EXTENSION(my_module)
  dnl Comments in this file start with the string 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])
  if 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,
  [ --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,
  [ --enable-my_module      Enable my_module support])
        (其实就是将这部分的dnl去掉,在这个文件里dnl就是注释的意思,相当于我们PHP里面的#或// 另外把他中间的一句描术也去掉)
  我这里用了后者
  然后保存退出
  然后在编辑
  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 sdomain!");
}
再修改:php_sdomain.h
vi php_sdomain.h
在PHP_FUNCTION(confirm_my_module_compiled ); /* For testing, remove later. */ 这行的下面添加一行:
PHP_FUNCTION(say_hello); /* For testing, remove later. */
  保存文件退出
  然后我们就可以在这个目录下使用上面的命令了
  /usr/local/php/bin/phpize
  执行以后会看到下面的
  [root@ns sdomain]# /usr/local/php/bin/phpize
  Configuring for:
  PHP Api Version:     20020918
  Zend Module Api No:   20020429
  Zend Extension Api No:  20050606
  [root@ns sdomain]#
  然后执行./configure --with-php-config=/usr/local/php/bin/php-config
  然后执行make
     make install
        然后他会把对应的so文件生成放到PHP安装目录下面的一个文件夹,并提示在在什么地方,然后再把里面的SO文件拷到你存放SO文件的地方
  即你在php.ini里面的extension_dir所指定的位置
  最后一步是你在php.ini文件中打开这个扩展
  extension=sdomain.so
  然后
  重新起动apache
  用phpinfo来察看一下ok了

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/sdomain/archive/2009/09/04/4520425.aspx
分享到:
评论

相关推荐

    使用phpize建立php扩展 今天要讲的是linux下php扩展的入门篇 下面我来 ....doc

    本文将介绍如何使用`phpize`工具创建一个基本的PHP扩展,以"jinzhesheng_module"为例进行详细讲解。 首先,确保你的系统上已经安装了PHP,并且知道PHP的安装位置。在示例中,PHP被安装在`/usr/local/php`目录下,其...

    不重新编译PHP为php增加openssl模块的方法

    代码如下:yum -y install openssl /usr/local/bin/是php的安装目录 切换到php安装目录的etx/openssl目录 cd /root/soft/php-5.2.8/ext/openssl 复制代码 代码如下: /usr/local/bin/phpize Cannot find config.m4....

    php教程之phpize使用方法

    - **找不到config.m4**:如果你遇到`Cannot find config.m4.`的错误,这通常是因为你没有在解压后的目录中运行`phpize`。确保在正确的位置执行`phpize`命令。 - **缺少autoconf**:如果在执行`phpize`时收到`Cannot...

    m4+autoconf 【Cannot find autoconf】

    phpize Configuring for: PHP Api Version: 20131106 ...Cannot find autoconf. Please check your autoconf installation and the $PHP_AUTOCONF environment variable. Then, rerun this script.

    linux下用phpize给PHP动态添加扩展.docx

    如果在编译PHP时没有开启`--enable-bcmath`选项,那么这个扩展将不会被编译进PHP,此时就需要通过`phpize`工具来动态添加。 `phpize`是PHP提供的一个脚本,用于准备构建和安装PHP扩展。要使用`phpize`,首先需要...

    PHP常见错误解决方案.docx

    通过以上步骤,我们可以有效地解决使用`phpize`为PHP动态添加扩展时遇到的“Cannot find autoconf”错误,以及为PHP添加`php-curl`扩展时的问题。这些解决方案不仅有助于开发者快速解决问题,还能够提高系统的稳定性...

    PHP动态编译出现Cannot find autoconf的解决方法

    2. 使用PHP的`phpize`工具初始化编译环境: ``` /usr/local/webserver/php/bin/phpize ``` 但在这个过程中,如果出现“Cannot find autoconf”的错误,意味着系统中没有找到`autoconf`或者它的路径没有正确设置。...

    php的扩展.pdf

    建立`config.m4` 这个文件用于配置扩展的编译选项。其内容如下: ```bash PHP_ARG_ENABLE(icbc, whether to enable ICBC support, [--enable-icbc Enable ICBC support]) if test "$PHP_ICBC" = "yes"; then AC_...

    PHP扩展开发.docx

    4. 测试扩展:使用`phpize`工具生成配置文件,然后`make test`进行测试。 5. 安装扩展:`sudo make install`将编译后的扩展安装到PHP的扩展目录。 6. 更新PHP配置:在php.ini中添加扩展,并重启服务器使更改生效。 7...

    php 扩展调用so动态库 教程

    编辑 `config.m4` 文件,选择使用 `enable` 选项,并删除注释。然后,修改 `hello.c` 和 `php_hello.h` 文件,添加 `hello_add` 函数。在 `hello.c` 文件中添加函数的定义,并在 `php_hello.h` 文件中声明该函数。 ...

    NNABC(PHP扩展).7z

    1. **源码结构**:解压NNABC扩展的源码后,你会发现一个标准的PHP扩展结构,包括`config.m4`(配置脚本)、`php_nnabc.h`(头文件)、`php_nnabc.c`(主实现文件)以及可能存在的其他辅助源文件和资源文件。...

    如何用C语言编写一个PHP的C扩展.zip

    3. **编写config.m4**:这个脚本用于检测系统是否满足编译扩展的条件,以及配置选项。你需要在其中调用`PHP_NEW_EXTENSION`宏来定义你的扩展名、版本信息等。 4. **定义头文件**:在`php_my_extension.h`中,定义...

    VC 建立php扩展

    为了调试和测试扩展,可以使用PHP的`phpize`工具生成配置脚本,然后通过`configure`和`make`命令进行编译。然而,由于这里提到的是使用VC,所以通常会使用Visual Studio的IDE来调试代码,这提供了更直观的断点和变量...

    使用c语言开发php扩展教程

    这将生成一系列文件,包括`config.m4`,你需要编辑这个文件并删除不需要的行。然后在扩展目录下运行`phpize`以生成必要的配置文件,接着执行`make`来编译代码。 为了使PHP识别你的扩展,你需要在`php.ini`中注册它...

    php7安装redis6扩展

    * 使用 phpize 生成 configure 配置文件:`phpize` * 配置扩展:`./configure --with-php-config=/usr/local/php/bin/php-config` * 编译扩展:`make` * 安装扩展:`make install` 3. 开启 Redis 扩展 安装完成后...

    phpize的深入理解

    例如,如果在执行phpize命令时出现 "Cannot find config.m4" 的错误提示,这意味着系统中缺少m4宏处理器或者环境变量配置不正确。此时,需要安装autoconf和m4工具。可以通过wget命令下载这两个工具的源码包,然后...

    php无需编译安装openssl扩展的实现方法

    在php中使用RSA算法的时候,需要调用openssl_get_publickey方法,但同时需要对php编译openssl扩展,否则...cp config0.m4 config.m4 phpize 此时会生成configure文件,这样就可以使用make命令安装 特别说明:需要设置

Global site tag (gtag.js) - Google Analytics