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,加密完成!"
 ?>

第二个方法

<?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 

 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之密码加密的几种方式
  • PHP实现加密的几种方式介绍
  • php 开发中加密的几种方法总结
  • php实现源代码加密的方法
(0)

相关推荐

  • PHP实现加密的几种方式介绍

    PHP中的加密方式有如下几种 1. MD5加密 string md5 ( string $str [, bool $raw_output = false ] ) 参数 str  --  原始字符串. raw_output  --  如果可选的 raw_output 被设置为 TRUE,那么 MD5 报文摘要将以16字节长度的原始二进制格式返回. 这是一种不可逆加密,执行如下的代码 $password = '123456'; echo md5($password); 得到结果是e10adc3949

  • php 开发中加密的几种方法总结

    1,使用crypt()函数进行加密 crypt()函数可以进行单项加密,具体语法如下: string crypt(string str[,tring salt]) 其中 str是要加密的字符串,salt为加密时使用的干扰串,如果省掉第二个参数,就会随机生成一个干扰串.crypt()函数支持四种算法和长度.具体如下表: 示例代码如下: <?php $str ="I'm jack!!!"; echo "加密前的str为:".$str."<br>

  • PHP之密码加密的几种方式

    PHP开发WEB应用程序,经常会完成用户注册信息,注册信息里面包括邮箱和密码的验证问题,这篇文章主要是针对密码加密的技师方式. MD5 相信很多PHP开发者在最先接触PHP的时候,处理密码的首选加密函数可能就是MD5了,我当时就是这样的: 复制代码 代码如下: $password = md5($_POST["password"]); 上面这段代码是不是很熟悉?然而MD5的加密方式目前在PHP的江湖中貌似不太受欢迎了,因为它的加密算法实在是显得有点简单了,而且很多破解密码的站点都存放了很

  • php实现源代码加密的方法

    本文实例讲述了php实现源代码加密的方法.分享给大家供大家参考.具体实现方法如下: <?php function RandAbc($length=""){//返回随机字符串 $str="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; return str_shuffle($str); } $filepath='index.php'; $path_parts= pathinfo($filepath);

  • PHP给源代码加密的几种方法汇总(推荐)

    虽说分享是传统的美德,但我们有时候辛辛苦苦写一些程序只是为了卖点小钱,挣点辛苦费,也防止有些没有道德的人倒卖,所以我们不得不对我们的程序进行加密,以下我们来介绍一下如何通过PHP的自定义函数来加密我们的PHP源代码. 第一个方法 <?php function encode_file_contents($filename) { $type=strtolower(substr(strrchr($filename,'.'),1)); if ('php' == $type && is_fil

  • Spring Boot 中密码加密的两种方法

    先说一句:密码是无法解密的.大家也不要再问松哥微人事项目中的密码怎么解密了! 密码无法解密,还是为了确保系统安全.今天松哥就来和大家聊一聊,密码要如何处理,才能在最大程度上确保我们的系统安全. 1.为什么要加密 2011 年 12 月 21 日,有人在网络上公开了一个包含 600 万个 CSDN 用户资料的数据库,数据全部为明文储存,包含用户名.密码以及注册邮箱.事件发生后 CSDN 在微博.官方网站等渠道发出了声明,解释说此数据库系 2009 年备份所用,因不明原因泄露,已经向警方报案,后又在

  • ubuntu下安装程序的三种方法总结(推荐)

    引言 在ubuntu当中,安装应用程序我所知道的有三种方法,分别是apt-get,dpkg安装deb和make install安装源码包三种.下面针对每一种方法各举例来说明. apt-get方法 使用apt-get install来安装应用程序算是最常见的一种安装方法了,比如我要安装build-essential这个软件,使用以下,他会帮我把所有的依赖包都一起安装了. sudo apt-get install build-essential 执行上述命令以后,我们可以看到一下信息,The fol

  • Ajax解决缓存的5种方法总结(推荐)

    1.在ajax发送请求前加上 anyAjaxObj.setRequestHeader("If-Modified-Since","0″). 2.在ajax发送请求前加上 anyAjaxObj.setRequestHeader("Cache-Control","no-cache"). 3.在URL后面加上一个随机数: "fresh=" + Math.random();. 4.在URL后面加上时间搓:"nowti

  • JS中动态创建元素的三种方法总结(推荐)

    1.动态创建元素一 document.write() 例如向页面中输出一个 li 标签 <pre class="html" name="code"><span style="font-size:12px;"><script> document.write("<li>123</li>"); </script></span> body标签中就会插入

  • Python中创建字典的几种方法总结(推荐)

    1.传统的文字表达式: >>> d={'name':'Allen','age':21,'gender':'male'} >>> d {'age': 21, 'name': 'Allen', 'gender': 'male'} 如果你可以事先拼出整个字典,这种方式是很方便的. 2.动态分配键值: >>> d={} >>> d['name']='Allen' >>> d['age']=21 >>> d[

  • Android开发之微信底部菜单栏实现的几种方法汇总

     实现方式 实现的方式有很多种 这里总结最常见的几种方式,以后再添加其他的. viewPager + RadioGroup viewPager + FragmentTabHost viewpager +TabLayout viewPager+RadioGroup 感觉这是最简单的一个了,我也就不贴代码 说说我理解的思路吧 通过给pager 和RadioGroup 添加监听,监听两个控件的变化 实现联动 当viewPager的显示pager改变就会触发监听 ,在监听中选中对应的RadioButto

  • 遍历python字典几种方法总结(推荐)

    如下所示: aDict = {'key1':'value1', 'key2':'value2', 'key3':'value3'} print '-----------dict-------------' for d in aDict: print "%s:%s" %(d, aDict[d]) print '-----------item-------------' for (k,v) in aDict.items(): print '%s:%s' %(k, v) #效率最高 prin

  • jquery的ajax提交form表单的两种方法小结(推荐)

    jquery的ajax提交form表单的两种方法小结(推荐) 方法一: function AddHandlingFeeToRefund() { var AjaxURL= "../OrderManagement/AjaxModifyOrderService.aspx"; alert($('#formAddHandlingFee').serialize()); $.ajax({ type: "POST", dataType: "html", url:

  • JavaScript中iframe实现局部刷新的几种方法汇总

    Iframe是一种嵌入网页的框架形式,Web页面可以通过更改嵌入的部分,达到部分内容刷新. Iframe的用法与普通的标签元素DIV类似,可以指定在页面中嵌入的位置.颜色.界面布局等 一.iframe实现局部刷新方法一 <script type="text/javascript"> $(function(){ $("#a1").click(function(){ var name= $(this).attr("name"); $(&q

随机推荐