php 5.6版本中編寫一個PHP擴展的簡單示例_PHP教程
推薦:PHP函數extension_loaded()用法實例這篇文章主要介紹了PHP函數extension_loaded()用法,實例分析了函數extension_loaded()檢查一個擴展是否已經加載的具體用法,并補充說明了查看本機已加載php擴展的方法,需要的朋友可以參考下 本文實例講述了PHP函數extension_loaded()用法。分享給大家供大家參考。具體分
這篇文章主要介紹了php 5.6版本中編寫一個PHP擴展的簡單示例,本文給出擴展實現代碼、編譯方法、配置方法和使用例子等內容,需要的朋友可以參考下
有時候在php本身沒有滿足需求的api時候,需要自己寫相應的擴展,擴展寫完之后進行編譯,即可加入自己的開發環境中,擴展php的功能。
這里實現一個連接字符串和int型數的連接操作的簡單擴展。
首先,下載最新的php源碼安裝包,進入ext/目錄,新建extstrcat.def:
代碼如下:string extstrcat(string strarg, int intarg)
隨后運行:
代碼如下:
./ext_skel --extname=extstrcat --proto=extstrcat.def
修改ext/extstrcat/config.m4,去掉如下行前面的注釋(dnl):
代碼如下:
PHP_ARG_ENABLE(extstrcat, whether to enable extstrcat support,
Make sure that the comment is aligned:
[ --enable-extstrcat Enable extstrcat support])
此時來編輯ext/extstrcat/extstrcat.c,找到PHP_FUNCTION(extstrcat)函數,這里表示擴展中的方法名為extstrcat,方法實現如下:
代碼如下:PHP_FUNCTION(extstrcat)
{
char *strarg = NULL;
int argc = ZEND_NUM_ARGS();
int strarg_len;
long intarg;
char intargstr[10];
int retstrlen = 0;
char *retstr = NULL;
if (zend_parse_parameters(argc TSRMLS_CC, "sl", &strarg, &strarg_len, &intarg) == FAILURE)
return;
snprintf(intargstr, 9, "%d", intarg);
retstrlen = strarg_len + strlen(intargstr) + 1;
retstr = (char *)malloc(sizeof(char)* retstrlen);
memset(retstr, '\0', retstrlen);
strncat(retstr, strarg, strlen(strarg));
strncat(retstr, intargstr, strlen(intargstr));
RETURN_STRING(retstr, 1);
php_error(E_WARNING, "extstract: not yet implemented");
}
,其中strarg和intarg即為對應的兩個字符串和整型參數。
接下來要做的事情就是編譯擴展,
phpize
./configure --enable-extstrcat
make
編譯成功之后,在ext/modules目錄下會生成extstrcat.so文件,
代碼如下:
cp ./modules/extstrcat.so /usr/local/lib/php/extensions/no-debug-non-zts-20121212/
修改php.ini,增加extension = extstrcat.so。
重啟php-fpm,運行phpinfo()可以看到新增了extstrcat擴展。
現在來寫一個Demo,測試一下剛剛的php擴展,
<?php
if(!extension_loaded('extstrcat')) {
dl('extstrcat.' . PHP_SHLIB_SUFFIX);
}
$ret=extstrcat('testarg',1234);
echo $ret;
?>
,命令行下運行該文件,得到testarg1234.
分享:php使用CURL偽造IP和來源實例詳解這篇文章主要介紹了php使用CURL偽造IP和來源的方法,以實例形式詳細分析了CURL偽造IP和來源的原理與實現技巧,并補充說明了PHP中的CURL函數庫常用函數,需要的朋友可以參考下 本文實例講述了php使用CURL偽造IP和來源的方法。分享給大家供大家參考。具體分析如下: 偽造IP來
- 相關鏈接:
- 教程說明:
PHP教程-php 5.6版本中編寫一個PHP擴展的簡單示例
。