`
cppupu
  • 浏览: 49060 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

PHP模块开发:第一篇 hello world!

    博客分类:
  • PHP
阅读更多

在一些必要的场景我们不得不自己开发出自己的本地PHP函数满足一些特定的需求,而新的函数必须存在于PHP模块中。下面将介绍最简单的PHP模块开发:构建自己的say_hello($arg)函数来输出hello world : $arg。

本文档介绍的PHP模块开发仅仅是动动手做做hello world的程度,关于为什么这么做暂时不会介绍太多,更加详细的介绍后续解剖。

php 环境的搭建请参考:。。。

下面通过简单的几个步骤可以完成模块hello world级别的模块:

  1. 生成模块基础结构
  2. 修改模块代码,添加say_hello 函数
  3. 修改编译配置文件
  4. 生成模块共享库
  5. 配置模块,使模块生效
  6. 测试模块

1、生成模块基础

进入php源代码目录下的ext目录。
执行./ext_skel ––extname=sayhello  (我这里的“–”编码有问题请不要直接拷贝)
输出:

[root@myhost ext]# ./ext_skel ––extname=sayhello
  1. Creating directory sayhello
  2. Creating basic files: config.m4 config.w32 .cvsignore sayhello.c php_sayhello.h CREDITS EXPERIMENTAL tests/001.phpt sayhello.php [done].
  3.  
  4. To use your new extension, you will have to execute the following steps:
  5.  
  6. 1.  $ cd ..
  7. 2.  $ vi ext/sayhello/config.m4
  8. 3.  $ ./buildconf
  9. 4.  $ ./configure ––[with|enable]-sayhello
  10. 5.  $ make
  11. 6.  $ ./php -f ext/sayhello/sayhello.php
  12. 7.  $ vi ext/sayhello/sayhello.c
  13. 8.  $ make
  14.  
  15. Repeat steps 3-6 until you are satisfied with ext/sayhello/config.m4 and
  16. step 6 confirms that your module is compiled into PHP. Then, start writing
  17. code and repeat the last two steps as often as necessary.

看到显示输出表示模块基础结构已经生成,我们来看下生成的模块包含哪些文件:

-rw-r–r– 1 root root 2103 Apr 9 05:05 config.m4              //编译配置文件
  1. -rw-r–r– 1 root root  310 Apr  9 05:05 config.w32             //w32编译配置文件
  2. -rw-r–r– 1 root root    8 Apr  9 05:05 CREDITS                //作者信息
  3. -rw-r–r– 1 root root    0 Apr  9 05:05 EXPERIMENTAL           //测试版信息标识
  4. -rw-r–r– 1 root root 2755 Apr  9 05:05 php_sayhello.h         //模块定义头文件
  5. -rw-r–r– 1 root root 5294 Apr  9 05:05 sayhello.c             //模块实现文件
  6. -rw-r–r– 1 root root  508 Apr  9 05:05 sayhello.php           //用来测试模块加载的php文件
  7. drwxr-xr-x 2 root root 4096 Apr  9 05:05 tests                  //测试文件目录

这个时候模块的骨架已经出来了,我们下一步就可以将目标的say_hello()函数加入。

2、实现say_hello()函数

打开模块的php_sayhello.h 文件,增加为php say_hello()准备的c函数定义:
PHP_FUNCTION(say_hello); //php 源代码为模块开放定义了许多宏,习惯了使用还是蛮方便的
增加完以后我们再对PHP_FUNCTION(say_hello)在say_hello.c中增加具体的实现:

PHP_FUNCTION(say_hello){
  1. char *arg = NULL;
  2. int arg_len;
  3.  
  4. if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &arg, &arg_len) == FAILURE) {  //获取php代码的输入参数,方式与scanf差不多
  5. return;
  6. }
  7. zend_printf("hello world : %s",arg)
  8. RETURN_STRINGL(arg, arg_len, 1);
  9. }

现在实现代码也写了,我们还需要将这个函数注册到php本地函数中,需要修改sayhello.c中的sayhello_functions:

zend_function_entry sayhello_functions[] = {
  1. PHP_FE(confirm_sayhello_compiled,    NULL)        /* For testing, remove later. */
  2. PHP_FE(say_hello,    NULL)        //好,现在say_hello函数也注册了
  3. {NULL, NULL, NULL}    /* Must be the last line in sayhello_functions[] */
  4. };

3、修改编译配置文件

打开config.m4,将以下内容前的注释符“dnl”去掉:

dnl PHP_ARG_ENABLE(sayhello, whether to enable sayhello support,
  1. dnl Make sure that the comment is aligned:
  2. dnl [  --enable-sayhello           Enable sayhello support])
  3.  
  4. dnl PHP_SUBST(SAYHELLO_SHARED_LIBADD)

4、编译模块、生成共享库

我这里采用的是动态库的模块生成方式,比静态编译进php速度快多了,方便调试(使用上并非用php的dl()函数加载动态库,后续可以看到)。

进入(cd) sayhello模块文件夹,执行php安装路径bin下的phpize:

[root@myhost sayhello]# /opt/php_server/php/bin/phpize
  1. Configuring for:
  2. PHP Api Version:         20041225
  3. Zend Module Api No:      20060613
  4. Zend Extension Api No:   220060519

此时为模块编译的configure文件已经生成。继续生成Makefile文件:

[root@myhost sayhello]# ./configure –with-php-config=/opt/php_server/php/bin/php-config

……没问题的话是没有错误的

现在可以编译了:

make

代码没有问题的话不会有错的。

编译完,进行模块安装:

[root@myhost sayhello]# make install
Installing shared extensions:     /opt/php_server/php/lib/php/extensions/no-debug-non-zts-20060613/

显示模块已经安装至/php安装路径/extensions/no-debug-non-zts-20060613/ 路径下了。

5、配置模块,使其被加载

打开你的php.ini文件开始修改吧:

扩展路径设置:

修改extension_dir = “/php安装路径/lib/php/extensions/no-debug-non-zts-20060613″ //看看上述的模块安装路径就知道了

增加模块设置:

[sayhello]
extension=sayhello.so

ok 大功告成,重新启动你的php模块把。

6、测试模块

写以下php测试代码执行:

<?php
  1. $a = say_hello("frank");
  2. echo "<br>";
  3. echo $a;
  4. ?>;

打开这个网页后显示:

hello world : frank
frank

成功运行,模块测试通过。
一个简单的hello world级别的php模块已经出来来了,虽然比较简单,许多内容也是知其然,但不知其所以然,不过后续会继续深入分析。

0
1
分享到:
评论

相关推荐

    python3基础教程(1).doc

    执行Python程序 对于大多数程序语言,第一个入门编程代码便是"Hello World!",以下代码为使用Python输出"Hello World!": 实例(Python 2.0+) #!/usr/bin/python print "Hello, World!"; 运行实例 » Python 3.0+...

    python3基础教程.doc

    执行Python程序 对于大多数程序语言,第一个入门编程代码便是"Hello World!",以下代码为使用Python输出"Hello World!": 实例(Python 2.0+) #!/usr/bin/python print "Hello, World!"; 运行实例 » Python 3.0+...

    python3基础教程(DOC65页).doc

    执行Python程序 关于大多数程序语言,第一个入门编程代码便是"Hello World!",以下代码为使用Python输出"Hello World!": 实例(Python 2.0+) #!/usr/bin/python print "Hello, World!"; 运行实例 » Python 3.0+...

    (完整word版)python3基础教程.doc

    执行Python程序 对于大多数程序语言,第一个入门编程代码便是"Hello World!",以下代码为使用Python输出"Hello World!": 实例(Python 2.0+) #!/usr/bin/python print "Hello, World!"; 运行实例 » Python ...

    python3基础教程.docx

    python3基础教程 python3基础教程全文共73页,当前为第1页。python3基础教程全文共73页,当前为第1页。... 执行Python程序 对于大多数程序语言,第一个入门编程代码便是"Hello World!",以下代码为使用Python

    PHP基础教程 是一个比较有价值的PHP新手教程!

    echo "Hello World!"; # Unix style single line comment ?&gt; 2.4 数据类型 PHP支持整数、浮点数、字符串、数组和对象。变量类型通常不由程序员决定而由PHP运行过程决定(真是好的解脱!)。但是类型也可以被函数...

    php网络开发完全手册

    1.3.1 第一个PHP程序Hello, world 6 1.3.2 学习PHP应该准备哪些软件 8 1.3.3 相关知识领域的介绍 9 1.4 程序运行环境的搭建 10 1.4.1 Apache简介 10 1.4.2 安装Apache与PHP 10 1.4.3 使用phpinfo()确认Apache与PHP ...

    运维管理发布系统.zip

    6: 第一次发布代码,需要初始化发布记录,直接在表ops_deploy_info 插入一条发布记录,版本号根据自己项目而定,发布到相应的环境需要初始换相应的target字段:如测试环境target为test,预生产环境为pre,正式环境...

    The Apache Modules Book Application Development with Apache

    记得刚开始的时候想进行apache模块开发的时候找了好多资料,不过大都是英文文档,几乎没有做系统讲解的。国内的图书更是没有这方面的,在Amozon搜索了下,找到了《Writing Apache Modules with Perl and C》和《The ...

    magento开发教程

    5.1配置资源,修改Helloworld模型的config.xml: 38 5.2创建资源类文件: 39 5.3创建安装脚本 39 5.4资源版本 40 5.5解剖配置脚本 42 5.6模块升级脚本 43 5.7总结 45 6.高级Magento模型EAV 45 6.1什么是EAV模型? ...

    Drupal-8-Module-Development-Second-Edition:Packt出版的Drupal 8 Module Development-Second Edition

    Drupal 8模块开发-第二版 这是Packt发布的的代码存储库。 使用最新版本的Drupal 8构建模块和主题 这本书是关于什么的? Drupal 8的发布周期允许以更快的速度添加新功能。 但是,这还意味着需要弃用代码并更改架构...

    iuhyiuhkjh908u0980

    我们的Hello World程序是你开发基于Struts2框架程序的第一步.这里我们会提供循序渐进的教程来开发基于Struts2框架的Hello World程序. 教程包含基本的步骤像创建目录结构,建立build.xml文件来使用Ant构建工具创建程序...

    Node.js 开发指南.pdf

    第1章 Node.js简介 1 1.1 Node.js是什么 2 1.2 Node.js能做什么 3 1.3 异步式I/O与事件驱动 4 1.4 Node.js的性能 5 1.4.1 Node.js架构简介 5 1.4.2 Node.js与PHP+Nginx 6 1.5 JavaScript简史 6 ...

    腾讯开源的手机前端开发调试利器 vConsole.zip

    因此,若要在引入模块后立即打印log,应使用vConsole.ready()方法:vConsole.ready(function() { console.log('Hello World');  });4 在线demo微信扫描以下二维码(或微信内长按图片识别二维码),即可体验...

    MySQL5 权威指南第3版中文版_part1

    第一部分 入门  第1章 什么是MySQL  1.1 什么是数据库  1.2 MySQL  1.3 MySQL的不足  1.4 MySQL的版本编号  1.5 MySQL的许可证  1.6 MySQL软件的替代品  1.7 小结  第2章 测试环境  2.1 是Windows还是UNIX...

    ICE分布式程序设计中文版

    第 3 章 Hello World 应用 33 3.1 本章综 33 3.2 编写 Slice 定义 33 3.3 编写使用 C++ 的 Ice应用 34 3.4 编写使用 Java的 Ice 应用 41 3.5 总结 48 第 Ice 核心概念 51 第 4 章 Slice 语言 53 4.1 本章综 53 4.2 ...

    Node.js+开发指南

    第1章 Node.js简介 1 1.1 Node.js是什么 2 1.2 Node.js能做什么 3 1.3 异步式I/O与事件驱动 4 1.4 Node.js的性能 5 1.4.1 Node.js架构简介 5 1.4.2 Node.js与PHP+Nginx 6 1.5 JavaScript简史...

    MySQL 5权威指南(第3版) 中文版 下载地址

     第1章 什么是MySQL  1.1 什么是数据库  1.2 MySQL  1.3 MySQL的不足  1.4 MySQL的版本编号  1.5 MySQL的许可证  1.6 MySQL软件的替代品  1.7 小结  第2章 测试环境  2.1 是Windows还是UNIX/...

    JAVA上百实例源码以及开源项目

     当用户发送第一次请求的时候,验证用户登录,创建一个该qq号和服务器端保持通讯连接得线程,启动该通讯线程,通讯完毕,关闭Scoket。  QQ客户端登录界面,中部有三个JPanel,有一个叫选项卡窗口管理。还可以更新...

Global site tag (gtag.js) - Google Analytics