[李景山php] PHP扩展开发系列教程2-通过php.ini初始化你扩展的配置

来源:互联网 发布:java localdate 编辑:程序博客网 时间:2024/05/20 06:53

通过php.ini初始化你扩展的配置


Zend引擎提供了两种管理ini值的途径。
假设你要在php.ini中为你的扩展定义一个值,hello.greeting,它保存将在hell_world()函数中用到的问候字符串。你需要向hello.c和php_hello.h中增加一些代码,同时对hell_module_entry结构作一些关键性的改变。

第一步:修改 php_hello.h中靠近用户空间函数的原型声明


PHP_MINIT_FUNCTION(hello);PHP_MSHUTDOWN_FUNCTION(hello);// 初始化关键点PHP_FUNCTION(hello_world);// 其它通用PHP_FUNCTION(hello_long);

第二步:修改 hello.c 文件


去掉当前版本中的 hello_module_entry 用下面的列表替换它:

zend_module_entry hello_module_entry = {     #if ZEND_MODULE_API_NO >= 20010901          STRANDARD_MODULE_HEADER,     #endif          PHP_HELLO_WORLD_EXTENAME,          hello_functions,          PHP_MINIT(hello),          PHP_MSHUTDOWN(hello),          NULL,NULL,NULL,     #if ZEND_MODULE_API_NO >= 20010901          PHP_HELLO_WORLD_VERSION,     #endif          STANDARD_MODULE_PROERTIES}PHP_INI_BEGIN()PHP_INI_ENTRY("hello.greeting","hello world",PHP_INI_ALL,NULL)PHP_INI_END()PHP_MINIT_FUNCTION(hello){     REGISTER_INI_ENTRIES();     return SUCCESS;}PHP_MSHUTDOWN_FUNCTION(hello){     UNREGISTER_INI_ENTRIES();     return SUCCESS;}

现在,你只需要在文件hello.c顶部的那些#include旁边增加一个#include,这样可以活动正确的支持INI的头文件:

#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "php.h"#include "php_ini.h"#include "php_hello.h"

最后,你可以修改hello_world让它使用INI的值:

PHP_FUNCTION(hello_world){     RETURN_STRING(INI_STR("hello.greeting"),1);}

但是:你将要拷贝从INI_STR()返回的值。这是因为,在进入PHP变量堆栈之前,它都是个静态字符串。实际上,如果你试图修改这个返回的字符串,PHP执行环境会变得不稳定,甚至崩溃。

总结:
其实就是使用
INI_STR()获取hello.greeting 条目的当前字符串。
如果要获取其它的参数,可以使用类似 INI_INT等,由于设置参数不一样可能导致,ini_set之类的函数不好用。