在一些必要的场景我们不得不自己开发出自己的本地PHP函数满足一些特定的需求,而新的函数必须存在于PHP模块中。下面将介绍最简单的PHP模块开发:构建自己的say_hello($arg)函数来输出hello world : $arg。
本文档介绍的PHP模块开发仅仅是动动手做做hello world的程度,关于为什么这么做暂时不会介绍太多,更加详细的介绍后续解剖。
php 环境的搭建请参考:。。。
下面通过简单的几个步骤可以完成模块hello world级别的模块:
- 生成模块基础结构
- 修改模块代码,添加say_hello 函数
- 修改编译配置文件
- 生成模块共享库
- 配置模块,使模块生效
- 测试模块
1、生成模块基础
进入php源代码目录下的ext目录。
执行./ext_skel ––extname=sayhello (我这里的“–”编码有问题请不要直接拷贝)
输出:
[root@myhost ext]# ./ext_skel ––extname=sayhello
-
Creating directory sayhello
-
Creating basic files: config.m4 config.w32 .cvsignore sayhello.c php_sayhello.h CREDITS EXPERIMENTAL tests/001.phpt sayhello.php [done].
-
-
To use your new extension, you will have to execute the following steps:
-
-
1. $ cd ..
-
2. $ vi ext/sayhello/config.m4
-
3. $ ./buildconf
-
4. $ ./configure ––[with|enable]-sayhello
-
5. $ make
-
6. $ ./php -f ext/sayhello/sayhello.php
-
7. $ vi ext/sayhello/sayhello.c
-
8. $ make
-
-
Repeat steps 3-6 until you are satisfied with ext/sayhello/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.
看到显示输出表示模块基础结构已经生成,我们来看下生成的模块包含哪些文件:
-rw-r–r– 1 root root 2103 Apr 9 05:05 config.m4 //编译配置文件
-
-rw-r–r– 1 root root 310 Apr 9 05:05 config.w32 //w32编译配置文件
-
-rw-r–r– 1 root root 8 Apr 9 05:05 CREDITS //作者信息
-
-rw-r–r– 1 root root 0 Apr 9 05:05 EXPERIMENTAL //测试版信息标识
-
-rw-r–r– 1 root root 2755 Apr 9 05:05 php_sayhello.h //模块定义头文件
-
-rw-r–r– 1 root root 5294 Apr 9 05:05 sayhello.c //模块实现文件
-
-rw-r–r– 1 root root 508 Apr 9 05:05 sayhello.php //用来测试模块加载的php文件
-
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){
-
char *arg = NULL;
-
int arg_len;
-
-
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &arg, &arg_len) == FAILURE) { //获取php代码的输入参数,方式与scanf差不多
-
return;
-
}
-
zend_printf("hello world : %s",arg);
-
RETURN_STRINGL(arg, arg_len, 1);
-
}
现在实现代码也写了,我们还需要将这个函数注册到php本地函数中,需要修改sayhello.c中的sayhello_functions:
zend_function_entry sayhello_functions[] = {
-
PHP_FE(confirm_sayhello_compiled, NULL) /* For testing, remove later. */
-
PHP_FE(say_hello, NULL) //好,现在say_hello函数也注册了
-
{NULL, NULL, NULL} /* Must be the last line in sayhello_functions[] */
-
};
3、修改编译配置文件
打开config.m4,将以下内容前的注释符“dnl”去掉:
dnl PHP_ARG_ENABLE(sayhello, whether to enable sayhello support,
-
dnl Make sure that the comment is aligned:
-
dnl [ --enable-sayhello Enable sayhello support])
-
-
dnl PHP_SUBST(SAYHELLO_SHARED_LIBADD)
4、编译模块、生成共享库
我这里采用的是动态库的模块生成方式,比静态编译进php速度快多了,方便调试(使用上并非用php的dl()函数加载动态库,后续可以看到)。
进入(cd) sayhello模块文件夹,执行php安装路径bin下的phpize:
[root@myhost sayhello]# /opt/php_server/php/bin/phpize
-
Configuring for:
-
PHP Api Version: 20041225
-
Zend Module Api No: 20060613
-
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
-
$a = say_hello("frank");
-
echo "<br>";
-
echo $a;
-
?>;
打开这个网页后显示:
hello world : frank
frank
成功运行,模块测试通过。
一个简单的hello world级别的php模块已经出来来了,虽然比较简单,许多内容也是知其然,但不知其所以然,不过后续会继续深入分析。
分享到:
相关推荐
"Hello World!" 是编程世界的入门程序,它标志着一个程序员的旅程开始。在大多数编程语言中,"Hello World!" 是编写的第一段代码,用于演示最基本的语法结构。这个简单的程序通常会打印出 "Hello World!" 这个字符串...
XML文件定义了模块的结构,是理解和创建新模块的第一步。 2. `helper.php`: 这个文件通常包含模块所需的辅助函数,可以处理一些复杂的逻辑或者数据操作。 3. `index.php`: 这是模块的视图文件,负责展示实际的前端...
创建“HelloWorld”模块的第一步是定义模块配置文件。在`app/etc`目录下创建一个名为`HelloWorld.xml`的文件。此文件将包含模块的基本信息,如版本号、依赖关系等。例如: ```xml <config xmlns:xsi=...
在许多编程语言中,初学者的第一个程序通常是打印“Hello, World!”。在 Python 2.0+版本中,你可以使用以下代码: ```python #!/usr/bin/python print "Hello, World!" ``` 然而,在 Python 3.0+版本中,`print` 被...
### PHPCMSV9控制器模块开发知识要点 #### 第一章 控制器概述 - **控制器定义**: 在MVC设计模式中,控制器是处理应用程序中用户交互的部分,它主要负责控制用户输入、调用模型处理数据以及选择合适的视图来展示...
在`MyCompanyName/HelloWorld/etc`目录下创建一个名为`config.xml`的文件,该文件用于定义模块的基本信息。 2. **编写`config.xml`** ```xml <MyCompanyName_HelloWorld> <version>0.1.0 ...
《Apache模块开发实例.doc》可能是系列教程的第一步,它可能包含了一些基本的模块开发示例,比如如何创建一个简单的"Hello, World!"模块,通过这个实例,读者可以了解模块的基本结构和工作原理。 《指南.doc》可能...
【标题】"helloworld"揭示的是一个初学者入门级别的编程示例,通常在学习新语言或框架时,第一个编写的程序就是"Hello, World!"。在这个特定的案例中,我们关注的是PHP,一种广泛用于服务器端脚本的编程语言。 ...
#### 1.1 输出 "Hello world!" 为了直观理解控制器的工作原理,我们可以创建一个简单的示例。创建一个名为`hello.php`的文件,写入以下代码: ```php class Hello { function index() { echo 'Hello World'; } ...
在Python 2中,可以使用如下代码打印"Hello, World!": ```python #!/usr/bin/python print "Hello, World!" ``` 而在Python 3中,`print`被改为内置函数,写法变为: ```python #!/usr/bin/python3 print("Hello, ...
扩展开发通常从创建一个简单的"Hello, World!"扩展开始。进入PHP源码的`ext`目录,这里是所有PHP扩展的存放地。使用`EXT_SKELETON`脚本创建扩展框架: ```bash ./EXT_SKELETON --EXTNAME=HELLOWORLD ``` 这会在`...
由Guido van Rossum于1989年创建,它在1991年发布了第一个版本,并且其源代码遵循GPL(GNU General Public License)协议,类似于Perl。 对于想要学习Python的人来说,这个教程非常适合那些没有或只有少量编程经验...
首先,你需要下载必要的软件包: ...记得在编写PHP代码时,可以测试简单的"Hello, World!"脚本,以确保环境配置无误。对于初学者来说,了解这个过程有助于理解Web开发的基础架构和组件之间的交互。
$obj->myVariable = "Hello, World!"; $obj->myMethod(); ``` 接下来,我们讨论一下类的继承(Inheritance)。继承允许子类(Subclass)从父类(Superclass)中继承属性和方法,减少了代码重复。在PHP5中,使用`...
- 测试PHP:创建一个简单的index.php文件,通过打印"Hello, World!"验证PHP是否正常工作。 3. PHP的运行模式: - CGI(Common Gateway Interface)模式:每个请求都会启动一个新的PHP进程。 - FastCGI模式:进程...
3. **创建第一个PHP程序**:在Apache的DocumentRoot目录下创建一个简单的PHP文件,例如`index.php`,写入`<?php echo "Hello, World!"; ?>`。 4. **运行和测试**:启动Apache服务器,通过浏览器访问`...
echo "Hello World!"; # Unix style single line comment ?> 2.4 数据类型 PHP支持整数、浮点数、字符串、数组和对象。变量类型通常不由程序员决定而由PHP运行过程决定(真是好的解脱!)。但是类型也可以被函数...