怎样给PHP源代码加密?PHP二进制加密与解密的解决办法


Posted in PHP onApril 22, 2013

分享2种PHP的源码加密方式,此加密方法支持任意PHP版。

注意,加密后的PHP代码无需第三方工具解密,像往常一样,直接运行即可。

<?php  
 function encode_file_contents($filename) {  
     $type=strtolower(substr(strrchr($filename,'.'),1));  
     if ('php' == $type && is_file($filename) && is_writable($filename)) { // 如果是PHP文件 并且可写 则进行压缩编码  
         $contents = file_get_contents($filename); // 判断文件是否已经被编码处理  
         $contents = php_strip_whitespace($filename);            // 去除PHP头部和尾部标识  
         $headerPos = strpos($contents,'<?php');  
         $footerPos = strrpos($contents,'?>');  
         $contents = substr($contents, $headerPos + 5, $footerPos - $headerPos);  
         $encode = base64_encode(gzdeflate($contents)); // 开始编码  
         $encode = '<?php'."\n eval(gzinflate(base64_decode("."'".$encode."'".")));\n\n?>";   
         return file_put_contents($filename, $encode);  
     }  
     return false;  
 }   
 //调用函数  
 $filename = 'dam.php';  
 encode_file_contents($filename);  
 echo "OK,加密完成!" 
 ?>

加密方式2:
<?php   function RandAbc($length = "") { // 返回随机字符串  
     $str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";  
     return str_shuffle($str);  
 }   
 $filename = 'index.php'; //要加密的文件  
 $T_k1 = RandAbc(); //随机密匙1  
 $T_k2 = RandAbc(); //随机密匙2  
 $vstr = file_get_contents($filename);  
 $v1 = base64_encode($vstr);  
 $c = strtr($v1, $T_k1, $T_k2); //根据密匙替换对应字符。  
 $c = $T_k1.$T_k2.$c;  
 $q1 = "O00O0O";  
 $q2 = "O0O000";  
 $q3 = "O0OO00";  
 $q4 = "OO0O00";  
 $q5 = "OO0000";  
 $q6 = "O00OO0";  
 $s = '$'.$q6.'=urldecode("%6E1%7A%62%2F%6D%615%5C%76%740%6928%2D%70%78%75%71%79%2A6%6C%72%6B%64%679%5F%65%68%63%73%77%6F4%2B%6637%6A");$'.$q1.'=$'.$q6.'{3}.$'.$q6.'{6}.$'.$q6.'{33}.$'.$q6.'{30};$'.$q3.'=$'.$q6.'{33}.$'.$q6.'{10}.$'.$q6.'{24}.$'.$q6.'{10}.$'.$q6.'{24};$'.$q4.'=$'.$q3.'{0}.$'.$q6.'{18}.$'.$q6.'{3}.$'.$q3.'{0}.$'.$q3.'{1}.$'.$q6.'{24};$'.$q5.'=$'.$q6.'{7}.$'.$q6.'{13};$'.$q1.'.=$'.$q6.'{22}.$'.$q6.'{36}.$'.$q6.'{29}.$'.$q6.'{26}.$'.$q6.'{30}.$'.$q6.'{32}.$'.$q6.'{35}.$'.$q6.'{26}.$'.$q6.'{30};eval($'.$q1.'("'.base64_encode('$'.$q2.'="'.$c.'";eval(\'?>\'.$'.$q1.'($'.$q3.'($'.$q4.'($'.$q2.',$'.$q5.'*2),$'.$q4.'($'.$q2.',$'.$q5.',$'.$q5.'),$'.$q4.'($'.$q2.',0,$'.$q5.'))));').'"));';  
 $s = '<?php '."\n".$s."\n".' ?>';  
 //echo $s;  
 // 生成 加密后的PHP文件  
 $fpp1 = fopen('temp_'.$filename, 'w');  
 fwrite($fpp1, $s) or die('写文件错误');  
 ?>

其实,PHP加密源码方式有很多,譬如,免费的微盾PHP加密,还有 www.phpjm.net 搞的在线加密,只是phpjm更复杂点而已。

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

另外,分享一个 PHP类,它能对 文本的内容进行 二进制加密 与 解密,代码如下:

<?php   class text_auth  
 {  
     var $n_iter;  
     function text_auth()  
     {  
         $this->setIter(32);  
     }  
     function setIter($n_iter)  
     {  
         $this->n_iter = $n_iter;  
     }  
     function getIter()  
     {  
         return $this->n_iter;  
     }  
     function encrypt($data, $key)  
     {  
         $n = $this->_resize($data, 4);  
         $data_long[0]   = $n;  
         $n_data_long    = $this->_str2long(1, $data, $data_long);  
         $n = count($data_long);  
         if (($n & 1) == 1) {  
             $data_long[$n] = chr(0);  
             $n_data_long++;  
         }  
         $this->_resize($key, 16, true);  
         if ( '' == $key )  
             $key = '0000000000000000';  
         $n_key_long = $this->_str2long(0, $key, $key_long);  
         $enc_data   = '';  
         $w          = array(0, 0);  
         $j          = 0;  
         $k          = array(0, 0, 0, 0);  
         for ($i = 0; $i < $n_data_long; ++$i) {  
             if ($j + 4 <= $n_key_long) {  
                 $k[0] = $key_long[$j];  
                 $k[1] = $key_long[$j + 1];  
                 $k[2] = $key_long[$j + 2];  
                 $k[3] = $key_long[$j + 3];  
             } else {  
                 $k[0] = $key_long[$j % $n_key_long];  
                 $k[1] = $key_long[($j + 1) % $n_key_long];  
                 $k[2] = $key_long[($j + 2) % $n_key_long];  
                 $k[3] = $key_long[($j + 3) % $n_key_long];  
             }  
             $j = ($j + 4) % $n_key_long;  
             $this->_encipherLong($data_long[$i], $data_long[++$i], $w, $k);  
             $enc_data .= $this->_long2str($w[0]);  
             $enc_data .= $this->_long2str($w[1]);  
         }  
         return $enc_data;  
     }  
     function decrypt($enc_data, $key)  
     {  
         $n_enc_data_long = $this->_str2long(0, $enc_data, $enc_data_long);  
         $this->_resize($key, 16, true);  
         if ( '' == $key )  
             $key = '0000000000000000';  
         $n_key_long = $this->_str2long(0, $key, $key_long);  
         $data   = '';  
         $w      = array(0, 0);  
         $j      = 0;  
         $len    = 0;  
         $k      = array(0, 0, 0, 0);  
         $pos    = 0;  
         for ($i = 0; $i < $n_enc_data_long; $i += 2) {  
             if ($j + 4 <= $n_key_long) {  
                 $k[0] = $key_long[$j];  
                 $k[1] = $key_long[$j + 1];  
                 $k[2] = $key_long[$j + 2];  
                 $k[3] = $key_long[$j + 3];  
             } else {  
                 $k[0] = $key_long[$j % $n_key_long];  
                 $k[1] = $key_long[($j + 1) % $n_key_long];  
                 $k[2] = $key_long[($j + 2) % $n_key_long];  
                 $k[3] = $key_long[($j + 3) % $n_key_long];  
             }  
             $j = ($j + 4) % $n_key_long;  
             $this->_decipherLong($enc_data_long[$i], $enc_data_long[$i + 1], $w, $k);  
             if (0 == $i) {  
                 $len = $w[0];  
                 if (4 <= $len) {  
                     $data .= $this->_long2str($w[1]);  
                 } else {  
                     $data .= substr($this->_long2str($w[1]), 0, $len % 4);  
                 }  
             } else {  
                 $pos = ($i - 1) * 4;  
                 if ($pos + 4 <= $len) {  
                     $data .= $this->_long2str($w[0]);  
                     if ($pos + 8 <= $len) {  
                         $data .= $this->_long2str($w[1]);  
                     } elseif ($pos + 4 < $len) {  
                         $data .= substr($this->_long2str($w[1]), 0, $len % 4);  
                     }  
                 } else {  
                     $data .= substr($this->_long2str($w[0]), 0, $len % 4);  
                 }  
             }  
         }  
         return $data;  
     }  
     function _encipherLong($y, $z, &$w, &$k)  
     {  
         $sum    = (integer) 0;  
         $delta  = 0x9E3779B9;  
         $n      = (integer) $this->n_iter;  
         while ($n-- > 0) {  
             $y      = $this->_add($y,  
                                   $this->_add($z << 4 ^ $this->_rshift($z, 5), $z) ^  
                                     $this->_add($sum, $k[$sum & 3]));  
             $sum    = $this->_add($sum, $delta);  
             $z      = $this->_add($z,  
                                   $this->_add($y << 4 ^ $this->_rshift($y, 5), $y) ^  
                                     $this->_add($sum, $k[$this->_rshift($sum, 11) & 3]));  
         }  
         $w[0] = $y;  
         $w[1] = $z;  
     }  
     function _decipherLong($y, $z, &$w, &$k)  
     {  
         $sum    = 0xC6EF3720;  
         $delta  = 0x9E3779B9;  
         $n      = (integer) $this->n_iter;  
         while ($n-- > 0) {  
             $z      = $this->_add($z,  
                                   -($this->_add($y << 4 ^ $this->_rshift($y, 5), $y) ^  
                                         $this->_add($sum, $k[$this->_rshift($sum, 11) & 3])));  
             $sum    = $this->_add($sum, -$delta);  
             $y      = $this->_add($y,  
                                   -($this->_add($z << 4 ^ $this->_rshift($z, 5), $z) ^  
                                         $this->_add($sum, $k[$sum & 3])));  
         }  
         $w[0] = $y;  
         $w[1] = $z;  
     }  
     function _resize(&$data, $size, $nonull = false)  
     {  
         $n      = strlen($data);  
         $nmod   = $n % $size;  
         if ( 0 == $nmod )  
             $nmod = $size;  
         if ($nmod > 0) {  
             if ($nonull) {  
                 for ($i = $n; $i < $n - $nmod + $size; ++$i) {  
                     $data[$i] = $data[$i % $n];  
                 }  
             } else {  
                 for ($i = $n; $i < $n - $nmod + $size; ++$i) {  
                     $data[$i] = chr(0);  
                 }  
             }  
         }  
         return $n;  
     }  
     function _hex2bin($str)  
     {  
         $len = strlen($str);  
         return pack('H' . $len, $str);  
     }  
     function _str2long($start, &$data, &$data_long)  
     {  
         $n = strlen($data);  
         $tmp    = unpack('N*', $data);  
         $j      = $start;  
         foreach ($tmp as $value)  
             $data_long[$j++] = $value;  
         return $j;  
     }  
     function _long2str($l)  
     {  
         return pack('N', $l);  
     }  
     function _rshift($integer, $n)  
     {  
         if (0xffffffff < $integer || -0xffffffff > $integer) {  
             $integer = fmod($integer, 0xffffffff + 1);  
         }  
         if (0x7fffffff < $integer) {  
             $integer -= 0xffffffff + 1.0;  
         } elseif (-0x80000000 > $integer) {  
             $integer += 0xffffffff + 1.0;  
         }  
         if (0 > $integer) {  
             $integer &= 0x7fffffff;  
             $integer >>= $n;  
             $integer |= 1 << (31 - $n);  
         } else {  
             $integer >>= $n;  
         }  
         return $integer;  
     }  
     function _add($i1, $i2)  
     {  
         $result = 0.0;  
         foreach (func_get_args() as $value) {  
             if (0.0 > $value) {  
                 $value -= 1.0 + 0xffffffff;  
             }  
             $result += $value;  
         }  
         if (0xffffffff < $result || -0xffffffff > $result) {  
             $result = fmod($result, 0xffffffff + 1);  
         }  
         if (0x7fffffff < $result) {  
             $result -= 0xffffffff + 1.0;  
         } elseif (-0x80000000 > $result) {  
             $result += 0xffffffff + 1.0;  
         }  
         return $result;  
     }  
 }  
 ?> 
使用方法参考如下:
// 加密过程
view sourceprint?
 $text_file = S_ROOT . './456.php';  
 $str = @file_get_contents($text_file);  
 require_once S_ROOT . "./text_auth.php";  
 $text_auth = new text_auth(64);  
 $str = $text_auth->encrypt($str, "qianyunlai.com");  
 $filename = S_ROOT . './789.php'; // 加密后的文本为二进制,普通的文本编辑器无法正常查看  
 file_put_contents($filename, $str); 
// 解密过程
view sourceprint
?01 $text_file = S_ROOT . './789.php';  
 $str = @file_get_contents($text_file);  
 require_once S_ROOT . "./text_auth.php";  
 $text_auth = new text_auth(64);  
 $str = $text_auth->decrypt($str, "qianyunlai.com");  
 $filename = S_ROOT . './456.php';  
 file_put_contents($filename, $str);

PHP 相关文章推荐
php adodb连接不同数据库
Mar 19 PHP
写出高质量的PHP程序
Feb 04 PHP
解析PHP实现多进程并行执行脚本
Jun 18 PHP
php获取域名的google收录示例
Mar 24 PHP
php+mysql实现简单的增删改查功能
Jul 13 PHP
Symfony2实现在doctrine中内置数据的方法
Feb 05 PHP
PHP微信开发之微信消息自动回复下所遇到的坑
May 09 PHP
Yii使用smsto短信接口的函数demo示例
Jul 13 PHP
Laravel学习教程之从入口到输出过程详解
Aug 27 PHP
php文件后缀不强制为.php的实操方法
Sep 18 PHP
tp5框架基于Ajax实现列表无刷新排序功能示例
Feb 10 PHP
PHP策略模式写法
Apr 01 PHP
基于PHP Web开发MVC框架的Smarty使用说明
Apr 19 #PHP
PHP时间戳与日期之间转换的实例介绍
Apr 19 #PHP
php多文件上传功能实现原理及代码
Apr 18 #PHP
php实现多张图片上传加水印技巧
Apr 18 #PHP
基于initPHP的框架介绍
Apr 18 #PHP
PHP header()函数使用详细(301、404等错误设置)
Apr 17 #PHP
ajax完美实现两个网页 分页功能的实例代码
Apr 16 #PHP
You might like
在PHP中使用Sockets 从Usenet中获取文件
2008/01/10 PHP
php 采集书并合成txt格式的实现代码
2009/03/01 PHP
smarty模板中拼接字符串的方法
2014/02/14 PHP
php unicode编码和字符串互转的方法
2020/08/12 PHP
phpstudy2018升级MySQL5.5为5.7教程(图文)
2018/10/24 PHP
PHP实现提取多维数组指定一列的方法总结
2019/12/04 PHP
基于jQuery的实现简单的分页控件
2010/10/10 Javascript
一款Jquery 分页插件的改造方法(服务器端分页)
2011/07/11 Javascript
jquery入门—编写一个导航条(可伸缩)
2013/01/07 Javascript
jQuery垂直多级导航菜单代码分享
2015/08/18 Javascript
JS获取元素多层嵌套思路详解
2016/05/16 Javascript
js代码实现下拉菜单【推荐】
2016/12/15 Javascript
微信小程序中实现一对多发消息详解及实例代码
2017/02/14 Javascript
React中ES5与ES6写法的区别总结
2017/04/21 Javascript
JS库 Highlightjs 添加代码行号的实现代码
2017/09/13 Javascript
Angular学习笔记之集成三方UI框架、控件的示例
2018/03/23 Javascript
RequireJS用法简单示例
2018/08/20 Javascript
[46:20]CHAOS vs Alliacne 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python中的__init__ 、__new__、__call__小结
2014/04/25 Python
python中ConfigParse模块的用法
2014/09/29 Python
在python中使用正则表达式查找可嵌套字符串组
2017/10/24 Python
python ffmpeg任意提取视频帧的方法
2020/02/21 Python
Python 实现使用空值进行赋值 None
2020/03/12 Python
翻转数列python实现,求前n项和,并能输出整个数列的案例
2020/05/03 Python
Python调用jar包方法实现过程解析
2020/08/11 Python
亚历山大·王官网:Alexander Wang
2017/06/23 全球购物
Shoes For Crews法国官网:美国领先的防滑鞋设计和制造商
2018/01/01 全球购物
20世纪40年代连衣裙和复古服装:The Seamstress Of Bloomsbury
2018/07/24 全球购物
娇韵诗香港官网:Clarins香港
2020/08/13 全球购物
个人自荐材料
2014/05/23 职场文书
公司自我介绍演讲稿
2014/08/21 职场文书
初中国旗下的演讲稿
2014/08/28 职场文书
大三学生学年自我鉴定
2014/09/12 职场文书
个人务虚会发言材料
2014/10/20 职场文书
党员作风建设整改方案
2014/10/27 职场文书
当你焦虑迷茫时,请读读这6句话
2019/07/24 职场文书