国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

修改Zend引擎實現(xiàn)PHP源碼加密的原理及實踐

2024-05-04 23:19:54
字體:
來源:轉載
供稿:網(wǎng)友
           PHP文件的源碼都是明文,這對于某些商業(yè)用途來說,并不適合。 因此考慮使用加密的手段保護源碼。 實在不耐煩等待zend出編譯器,而且編譯和加密本質上不是一回 事兒。自己動手、開始修改。

一、基本原理 
  考慮截獲PHP讀取源文件的接口。一開始,我考慮從Apache和PHP 之間的接口處處理,參見apache的src/modules/php4/mod_php4.c (這個是PHP用static方式編譯進apache,make install 后的文件),在send_php()函數(shù)中截獲文件指針,采用臨時文件的方式,解密后替換文件指針。這種方法經(jīng)過測試實踐,證明是可行的。但是,必須使用兩次文件操作,效率低下,而且對于DSO方式不可采用。 雙緣敬老院 
  由此,重新考慮截獲PHP讀取文件并裝載至緩存的過程,經(jīng)過費力的尋找,發(fā)現(xiàn)在Zend引擎中zend-scanner.c是做此處理的。開始對此文件修改。照明工程 

二、實現(xiàn)方法示意 

  采用libmcrypt作為加 密模塊,現(xiàn)在采用的是DES方法ECB模式加密, 

下面是文件加密的源代碼: 

C++代碼 
/* ecb.c-------------------cut here-----------*/    
/* encrypt for php source code version 0.99 beta    
we are using libmcrypt to encrypt codes, please    
install it first.    
compile command line:    
gcc -O6 -lmcrypt -lm -o encryptphp ecb.c    
please set LD_LIBRARY_PATH before use.    
GNU copyleft, designed by wangsu , miweicong */    

#define MCRYPT_BACKWARDS_COMPATIBLE 1     
#define PHP_CACHESIZE 8192     
#include < mcrypt.h >     
#include < stdio.h >     
#include < stdlib.h >     
#include < math.h >     
#include < sys/types.h >     
#include < sys/stat.h >     
#include < fcntl.h >     

    
main(int argc, char** argv)     
{     

int td, i,j,inputfilesize,filelength;     
char filename[255];     
char password[12];     
FILE* ifp;     
int readfd;     
char *key;     
void *block_buffer;     
void *file_buffer;     
int keysize;     
int decode=0;     
int realbufsize=0;     
struct stat *filestat;     

    
if(argc == 3) {     
strcpy(password,argv[1]);     
strcpy(filename,argv[2]);     
} else if(argc == 4 && !strcmp(argv[1],"-d")){     
strcpy(password,argv[2]);     
strcpy(filename,argv[3]);     
decode=1;     
printf("Entering decode mode ... n");     
} else {     
printf("Usage: encryptphp [-d] password filenamen");     
exit(1);     
}     

    
keysize=mcrypt_get_key_size(DES);     
key=calloc(1, mcrypt_get_key_size(DES));     

gen_key_sha1( key, NULL, 0, keysize, password, strlen(password));     
td=init_mcrypt_ecb(DES, key, keysize);     

if((readfd=open(filename,O_RDONLY,S_IRUSR|S_IWUSR|S_IRGRP))==-1){     
printf("FATAL: Can't open file to read");     
exit(3);     
}     

filestat=malloc(sizeof(stat));     

fstat(readfd,filestat);     
inputfilesize=filestat- >st_size;     
printf("filesize is %d n",inputfilesize);     
filelength=inputfilesize;     

inputfilesize=((int)(floor(inputfilesize/PHP_CACHESIZE))+1)*PHP_CACHESIZE;     

if((file_buffer=malloc(inputfilesize))==NULL){     
printf("FATAL: can't malloc file buffer.n");     
exit(2);     
}     
if((block_buffer=malloc(PHP_CACHESIZE))==NULL){     
printf("FATAL: can't malloc encrypt block buffer.n");     
exit(2);     
}     

j=0;     
while(realbufsize=read (readfd,block_buffer, PHP_CACHESIZE)){     
printf(".");     
if(!decode){     
if(realbufsize< PHP_CACHESIZE){     
for(i=realbufsize;i< PHP_CACHESIZE;i++){     
((char *)block_buffer)[i]=' ';     
}     
}     
mcrypt_ecb (td, block_buffer, PHP_CACHESIZE);     
} else {     
mdecrypt_ecb (td, block_buffer, realbufsize);     
}     
memcpy(file_buffer+j*PHP_CACHESIZE,block_buffer,PHP_CACHESIZE);     
j++;     
}     

close(readfd);     

if((ifp=fopen(filename,"wb"))==NULL){     
printf("FATAL: file access error.n");     
exit(3);     
}     
fwrite ( file_buffer, inputfilesize, 1, ifp);     

free(block_buffer);     
free(file_buffer);     
free(filestat);     
fclose(ifp);     
printf("n");     

return 0;     

}     
/*--- end of ecb.c ------------------------------------*/    
因為ECB模式是塊長度確定的塊加密,這里填充了一 些空字符。國際展覽 

  然后,修改php代碼中 Zend/zend-scanner.c 如下: 

(我的php版本是4.01pl2, SUNsparc/solaris 2.7, gcc 2.95;) 

文件前加入: 

#define MCRYPT_BACKWARDS_COMPATIBLE 1 
#include < mcrypt.h > 

  然后,注釋掉大約3510行前后的YY_INPUT的定義。 

  然后, 修改大約5150行前后的yy_get_next_buffer()函數(shù): 
函數(shù)頭加上定義: 
void *tempbuf; 
char *key; 
char debugstr[255]; 
int td,keysize; 
int x,y; 
FILE *fp; 
然后 ,注釋掉 
YY_INPUT( (&yy_current_buffer- >yy_ch_buf[number_to_move]), 
yy_n_chars, num_to_read ); 
這一句。 
改為: 

tempbuf=malloc(num_to_read); 
if((yy_n_chars=fread(tempbuf,1,num_to_read,yyin))!=0){ 
/*decode*/ 
#define password "PHPphp111222" 
#define debug 0 

keysize=mcrypt_get_key_size(DES); 
key=calloc(1, mcrypt_get_key_size(DES)); 
gen_key_sha1( key, NULL, 0, keysize, password, strlen(password)); 
td=init_mcrypt_ecb(DES, key, keysize); 
mdecrypt_ecb(td, tempbuf, yy_n_chars); 
memcpy((&yy_current_buffer- >yy_ch_buf[number_to_move]),tempbuf,yy_n_chars); 
if(debug){ 
fp=fopen("/tmp/logs","wb"); 
fwrite("nstartn",7,1,fp); 
fwrite(tempbuf,1,yy_n_chars,fp); 
fwrite("nenditn",7,1,fp); 
fclose(fp); 


free(tempbuf); 

  然后,編譯php,按正常方法安裝即可,因為我對于libtool不太熟悉,因此我選擇static方式,并在 configure時加入了--with-mcrypt,這樣我就不用自己手工修改Makefile 電纜橋架 

三、測試及結果 

  編譯php,apache后,用ecb.c編譯出來的encryptphp加密了幾個文件,分別為< 1K,10K+,和40K+,在處理 40K大小文件時出錯,別的文件均正常。塑膠地板 
  這是因為塊的ECB加密方式?jīng)Q定了必須使用定長塊,所以,請 諸位同好指點采用何種流加密方式可以兼顧到zend每次讀取8192字節(jié)的緩存處理方式。(其他平臺上 zend每次讀取的塊長度可能有所不同)  
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 信宜市| 澄城县| 宁津县| 木兰县| 韶关市| 尉氏县| 缙云县| 中阳县| 江津市| 泾阳县| 吉木萨尔县| 乐平市| 海口市| 深圳市| 洛阳市| 永修县| 乌鲁木齐市| 伊吾县| 湄潭县| 德江县| 于都县| 乐亭县| 南阳市| 巴彦淖尔市| 孝义市| 廉江市| 泾川县| 乌兰察布市| 南华县| 巴彦淖尔市| 革吉县| 彰化市| 安图县| 南康市| 昆山市| 鱼台县| 都昌县| 三亚市| 卓尼县| 锡林浩特市| 桑日县|