PHPCPP安裝以及hello world

學習了一段時間作PHP擴展開發,因爲C的難度較大,內存回收,指針每個均可以能讓初學者望而卻步,加上C開發效率過低,小型企業對於這種高大上的開發,仍是少觸碰爲好。可是有時候PHP開發執行效率確實過低,並且存在很大的資源浪費,而且這個又是沒法避免的(好比excel),混合開發讓項目的遷移和可維護性都下降了。php

一次偶然機會發現了PHPCPP,C++開發PHP的擴展,C++不用說了吧!執行效率最接近C的語言。最主要的是PHPCPP大大的下降了PHP擴展的開發難度。之前開發擴展,初始化項目對於小白來講均可能是個災難,而PHPCPP對於但願開發擴展的PHPER能夠說是一個福音。linux

在不接觸PHP底層的狀況下,採用PHPCPP是一個很好的選擇方案。下面廢話很少說,上乾貨。ios

首先選擇一個你經常使用的linux版本,而後下載PHPCPPc++

git clone https://github.com/CopernicaMarketingSoftware/PHP-CPP.git

而後編譯並安裝PHPCPPgit

make &&sudo  make install

這樣PHPCPP就安裝成功了。github

從PHPCPP下載一個空項目http://www.php-cpp.com/EmptyE...shell

這裏說明一下,默認最新PHPCPP是隻支持PHP7的,若是須要支持PHP5.X須要下載他的另一個版本,API同樣,只是sdk不一樣,因此採用PHPCPP開發的擴展源碼是相通的,只是須要在對應版本編譯。app

言歸正傳,空項目中的Makefile,能夠修改NAME,這個是你的擴展文件名稱,其餘都保持不變less

#
#   Makefile template
#
#   This is an example Makefile that can be used by anyone who is building
#   his or her own PHP extensions using the PHP-CPP library. 
#
#   In the top part of this file we have included variables that can be
#   altered to fit your configuration, near the bottom the instructions and
#   dependencies for the compiler are defined. The deeper you get into this
#   file, the less likely it is that you will have to change anything in it.
#

#
#   Name of your extension
#
#   This is the name of your extension. Based on this extension name, the
#   name of the library file (name.so) and the name of the config file (name.ini)
#   are automatically generated
#

NAME                =   yourextension

#
#   Php.ini directories
#
#   In the past, PHP used a single php.ini configuration file. Today, most
#   PHP installations use a conf.d directory that holds a set of config files,
#   one for each extension. Use this variable to specify this directory.
#
#   In Ubuntu 14.04 Apache 2.4 is used, which uses the mods-available directory
#   instead of a conf.d directory. In 16.04 the directory changed yet again.
#   This has to be checked.
#

UBUNTU_MAJOR  := $(shell /usr/bin/lsb_release -r -s | cut -f1 -d.)
OVER_SIXTEEN  := $(shell echo "${UBUNTU_MAJOR} >= 16" | bc)
OVER_FOURTEEN := $(shell echo "${UBUNTU_MAJOR} >= 14" | bc)

ifeq (${OVER_SIXTEEN}, 1)
    INI_DIR     =   /etc/php/7.0/mods-available/
else ifeq (${OVER_FOURTEEN}, 1)
    INI_DIR     =   /etc/php5/mods-available/
else
    INI_DIR     =   /etc/php5/conf.d/
endif

#
#   The extension dirs
#
#   This is normally a directory like /usr/lib/php5/20121221 (based on the 
#   PHP version that you use. We make use of the command line 'php-config' 
#   instruction to find out what the extension directory is, you can override
#   this with a different fixed directory
#

EXTENSION_DIR       =   $(shell php-config --extension-dir)

#
#   The name of the extension and the name of the .ini file
#
#   These two variables are based on the name of the extension. We simply add
#   a certain extension to them (.so or .ini)
#

EXTENSION           =   ${NAME}.so
INI                 =   ${NAME}.ini

#
#   Compiler
#
#   By default, the GNU C++ compiler is used. If you want to use a different
#   compiler, you can change that here. You can change this for both the 
#   compiler (the program that turns the c++ files into object files) and for
#   the linker (the program that links all object files into the single .so
#   library file. By default, g++ (the GNU C++ compiler) is used for both.
#

COMPILER            =   g++
LINKER              =   g++

#
#   Compiler and linker flags
#
#   This variable holds the flags that are passed to the compiler. By default, 
#   we include the -O2 flag. This flag tells the compiler to optimize the code, 
#   but it makes debugging more difficult. So if you're debugging your application, 
#   you probably want to remove this -O2 flag. At the same time, you can then 
#   add the -g flag to instruct the compiler to include debug information in
#   the library (but this will make the final libphpcpp.so file much bigger, so
#   you want to leave that flag out on production servers).
#
#   If your extension depends on other libraries (and it does at least depend on
#   one: the PHP-CPP library), you should update the LINKER_DEPENDENCIES variable
#   with a list of all flags that should be passed to the linker.
#

COMPILER_FLAGS      =   -Wall -c -O2 -std=c++11 -fpic -o
LINKER_FLAGS        =   -shared
LINKER_DEPENDENCIES =   -lphpcpp

#
#   Command to remove files, copy files and create directories.
#
#   I've never encountered a *nix environment in which these commands do not work. 
#   So you can probably leave this as it is
#

RM                  =   rm -f
CP                  =   cp -f
MKDIR               =   mkdir -p

#
#   All source files are simply all *.cpp files found in the current directory
#
#   A built-in Makefile macro is used to scan the current directory and find 
#   all source files. The object files are all compiled versions of the source
#   file, with the .cpp extension being replaced by .o.
#

SOURCES             =   $(wildcard *.cpp)
OBJECTS             =   $(SOURCES:%.cpp=%.o)

#
#   From here the build instructions start
#

all:                    ${OBJECTS} ${EXTENSION}

${EXTENSION}:           ${OBJECTS}
                        ${LINKER} ${LINKER_FLAGS} -o $@ ${OBJECTS} ${LINKER_DEPENDENCIES}

${OBJECTS}:
                        ${COMPILER} ${COMPILER_FLAGS} $@ ${@:%.o=%.cpp}

install:        
                        ${CP} ${EXTENSION} ${EXTENSION_DIR}
                        ${CP} ${INI} ${INI_DIR}

clean:
                        ${RM} ${EXTENSION} ${OBJECTS}
main.c源碼
#include <phpcpp.h>
#include <iostream>

void myFunction()
{
    Php::out << "hello world" << std::endl;
}

extern "C" {
    PHPCPP_EXPORT void *get_module() {
        static Php::Extension extension("my_extension", "1.0");
        extension.add<myFunction>("myFunction");
        return extension;
    }
}

這樣一個擴展代碼就完成了,執行編譯ide

make
而後將生成的xxx.so拷貝到PHP擴展目錄,並在PHP.INI加入
extension=yourextension.so

執行php -m查看是否加載了擴展,若是已經成功加載那麼,就會顯示my_extension在裏面了

php  -m

那麼PHP中如何調用呢?若是沒有使用命名空間那麼能夠這樣

<?php
   myFunction();

若是使用了須要加上\

<?php
 \myFunction();

這樣第一個擴展就完成了。

之後會每週至少更新兩篇關於PHPCPP的文章記錄並分享本身的使用PHPCPP的開發經驗。

相關文章
相關標籤/搜索