久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

實現PHP的編譯執行分離(separating compilation and execution)

瀏覽:35日期:2024-02-17 13:43:48

剛剛在PHP群內和大家聊天,應承了大家要寫一個關于如何實現PHP源碼加密的文章,借著這會QA在冒煙的機會,就這個問題,我寫點思路。

我以前的文章介紹過,ZE(Zend engine)執行一個PHP腳本會經歷編譯->執行,只不過它每次執行都會去重新編譯PHP文件。并沒有實現編譯和執行分離。

在ZE的編譯和執行階段,有倆個重要的函數:

ZEND_API zend_op_array *(*zend_compile_file)(zend_file_handle *file_handle, int type TSRMLS_DC);

ZEND_API void (*zend_execute)(zend_op_array *op_array TSRMLS_DC);

zend_compile_file負責將要執行的腳本文件編譯成由ZE的基本指令序列構成的op codes,然后將op codes交由zend_execute執行,從而得到我們腳本的結果。

所以,我們完全可以通過修改默認的zend_complie_file和zend_execute來實現,PHP的執行和編譯分離,進一步,我們還可以再這個基礎上實現,對我們腳本的加密和解密。

我們通過一個PHP擴展模塊來實現這個功能,首先,我們需要在模塊初始化的時候:

PHP_MINIT_FUNCTION(sample){ old_compile_file = zend_compile_file//保存現場 old_execute = zend_execute; zend_compile_file = my_compile_file; //截獲 zend_execute = my_execute; return SUCCESS;}

在我們的my_compile_file中,判斷我們的文件是否是編譯過的文件,假設后綴名是*.ze。

static zend_op_array *my_compile_file(zend_file_handle *file_handle, int type TSRMLS_DC){ if(strstr(file_handle->filename, '.ze') != NULL){//是編譯過的文件。 直接返回文件內容. } zend_op_array *op_array;

op_array = old_compile_file (file_handle, type TSRMLS_CC); //調用默認的compile,截獲輸出 if(op_array){ 保存op_array; } return op_array;}

這樣,我們就實現了,對已經編譯文件的支持,和對文件編譯的支持。

然后,需要編寫我們的執行函數:

static void my_execute(zend_op_array *op_array TSRMLS_DC){ old_execute(op_array TSRMLS_DC); //簡單交由默認執行函數執行。}

也許你要問為什么要包裝以后的執行函數,呵呵,我只是為了說明,一種方式,就是可以截獲這個東東而已。有什么用?就看讀者你有什么要求能通過這個方式實現了: )。

寫到這里,你也許就明白了,如果想要對文件加密,那么就定義個加密文件類型,比如*.zec,然后在my_compile_file中,判斷文件類型,如果是加密文件,那么就執行解密,嘿嘿,簡單吧?

至于怎么加密,那就要問你自己了,你想用什么方式,但是,記住,要可逆的哦~~^_^。

標簽: PHP
主站蜘蛛池模板: 南安市| 周宁县| 成都市| 涟水县| 富裕县| 惠州市| 高邮市| 潜江市| 元谋县| 闽侯县| 泸西县| 巩义市| 北海市| 二连浩特市| 吉安县| 东平县| 平顶山市| 化隆| 句容市| 宜良县| 叶城县| 义马市| 陆河县| 临桂县| 大埔县| 山西省| 山丹县| 都安| 宜昌市| 保德县| 木兰县| 浦城县| 屯门区| 金山区| 绥江县| 黑河市| 汝城县| 通许县| 曲阜市| 万宁市| 海宁市|