백엔드 개발 PHP 튜토리얼 编写自己的php扩展函数_PHP

编写自己的php扩展函数_PHP

Jun 01, 2016 pm 12:35 PM
php 기능 확장하다 쓰다 소유하다

Yorgo Sun 2002/01/22

php程序写的时间长了
自然对他所提供的功能了如指掌他所提供的一大堆功能真是觉得很好用但有时候会发现php也缺少一些功能自己总是会产生为php添加一些自定义的功能的想法。久而久之终于今天憋不住了开始动手研究如何添加。

下载一个php的源代码包
这里使用的是php 4.0.5版解压后会看到php的根目录下会有README.EXT_SKEL这样一个文件打开详细阅读了一下发现了一个非常好用的工具这个工具可以帮你构建一个空的php扩展然后你向里面添加相应的代码就可以完成你自己的功能扩展了。下面我们就来介绍如何使用这个工具。



首先转移你的目录到php的目录下的ext目录
如果你只需要一个基本的扩展框架的话执行下面的命令



./ext_skel --extname=module_name



module_name是你自己可以选择的扩展模块的名字
例如我选择的my_module。执行工具后会自动在ext目录下建立你选择的module_name名字的目录里面已经生成了相关的代码这些代码中只需要调整config.m4文件中的三行注释就可以正常的编译带这个自定义扩展模块的php了。在php的根目录执行下列操作就可以得到。

.
/buildconf



.
/configure --enable-module_name



make

下面我来演示建立my_module扩展框架的全过程
为了更有效果我们来完成一个php的扩展功能在php中调用这个功能可以在web页面中显示hello world这个经典单词。



在php目录下的ext目录中
执行下面的命令



.
/ext_skel --extname=my_module



得到反馈结果




Creating directory my_module



Creating basic files
: config.m4 Makefile.in .cvsignore my_module.c php_my_module.h tests/001.phpt my_module.php [done].




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



1.  $ cd ..



2
.  $ vi ext/my_module/config.m4



3
.  $ ./buildconf



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



5
.  $ make



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



7
.  $ vi ext/my_module/my_module.c



8
.  $ make



Repeat steps 3
-6 until you are satisfied with ext/my_module/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.



 



如果你能看懂上面的东西
那就照着去做。如果不是太明白的话按照我下面的提示来做也可以。



Cd my_module



首先进入my_module目录



vi config
.m4



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



dnl $Id$



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 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,



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文本编辑器的操作有困难的话请参考相应的说明文章这里就不再详细描述了。



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 world\n");



}



保存文件退出



 



vi php_my_module.h



在文件中PHP_FUNCTION(confirm_my_module_compiled);一行前面添加下面的代码



PHP_FUNCTION(say_hello);



保存文件退出



 



退回到php的根目录下执行下面的命令



./buildconf



./configure --enable-my_module



make



 



如果一切顺利的话我们现在已经将扩展模块my_module编译到php里面了。我们编写下面的代码进行测试







       Say_hello();



?>



保存文件为say_hello
.php



在php的根目录下运行



.
/php –q say_hello.php



正常情况下会显示



hello world



表示我们的第一个扩展正常的运行了




 



解释一下上面做的操作
ext_skel生成一些框下文件我们需要修改以下文件



my_module
.c  扩展模块的主程序



php_my_module
.h 扩展模块的头文件



config
.m4  配置文件



 



主程序中描述了php扩展模块的声明
模块中含有多少个函数各个函数的作用在phpinfo函数中显示什么内容模块初始化做些什么结束做些什么都会在这个文件里进行描述。我们在上面只是添加了一个函数say_hello并且描述了say_hello函数的具体内容调用zend_printf系统函数在php中打印字符串。



 



在对应的头文件中声明了say_hello这个函数
从而完成了我们预期的功能。下面我们会编写一个更复杂的扩展创造一个带参数的php扩展函数根据给入的参数显示hello world, xxxx。Xxxx代表输入的字符串内容例如我的名字yorgo。



 



Vi my_module
.c



修改最后的say_hello函数内容如下




PHP_FUNCTION(say_hello)



{



        zval **yourname;



 



       
if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &yourname) == FAILURE)



        {



                WRONG_PARAM_COUNT;



        }



 



        zend_printf
("hello world, %s\n", Z_STRVAL_PP(yourname));



}



存盘退出。



退回php的根目录
运行



make



修改say_hello
.php为







       Say_hello
(“yorgo”);



?>



保存退出后运行



.
/php –q say_hello.php



得出结果



hello world
, yorgo



表示我们这次的修改也成功了
可以改变say_hello中的参数看看动态的效果。



这里主要解释上面修改的函数内容
由于say_hello函数需要有参数引入所以在my_module.c中的say_hello函数主要在进行参数的处理将php中引用say_hello时所填写的参数内容正确的传递到my_module.c中的say_hello处理函数中。为此程序中添加了这么几行。



zval
**yourname;



if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &yourname) == FAILURE)



{



WRONG_PARAM_COUNT;



}



zend_printf("hello world, %s\n", Z_STRVAL_PP(yourname));



 



代码解释如下




zval **yourname;



初始化一个参数的指针



ZEND_NUM_ARGS
()



得到传递过来得参数数量并且判断如果不为1的时候表示有问题报错。



zend_get_parameters_ex
(1, &yourname)



将刚刚初始化的指针指向传递过来的参数如果不成功则报错。



Z_STRVAL_PP
(yourname)



处理指针指向的参数并获得实际存储的值。



(待续)



欢迎网上转载但请保留作者的版权声明如需线下刊登、发表请与作者联系yorgo@163.net  http://www.ruisoft.

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

cakephp4에서 날짜와 시간을 다루기 위해 사용 가능한 FrozenTime 클래스를 활용하겠습니다.

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

파일 업로드 작업을 위해 양식 도우미를 사용할 것입니다. 다음은 파일 업로드의 예입니다.

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

이번 장에서는 라우팅과 관련된 다음과 같은 주제를 학습하겠습니다.

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP 유효성 검사기 만들기 CakePHP 유효성 검사기 만들기 Sep 10, 2024 pm 05:26 PM

컨트롤러에 다음 두 줄을 추가하면 유효성 검사기를 만들 수 있습니다.

See all articles