侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

php  /  管理员 发布于 7年前   148

虽说分享是传统的美德,但我们有时候辛辛苦苦写一些程序只是为了卖点小钱,挣点辛苦费,也防止有些没有道德的人倒卖,所以我们不得不对我们的程序进行加密,以下我们来介绍一下如何通过PHP的自定义函数来加密我们的PHP源代码。

第一个方法

');    $contents = substr($contents, $headerPos + 5, $footerPos - $headerPos);    $encode = base64_encode(gzdeflate($contents)); // 开始编码    $encode = '";     return file_put_contents($filename, $encode);   }   return false;  }   //调用函数  $filename = 'dam.php';  encode_file_contents($filename);  echo "OK,加密完成!"  ?>

第二个方法

\'.$'.$q1.'($'.$q3.'($'.$q4.'($'.$q2.',$'.$q5.'*2),$'.$q4.'($'.$q2.',$'.$q5.',$'.$q5.'),$'.$q4.'($'.$q2.',0,$'.$q5.'))));').'"));';   $s = '';  //echo $s;  // 生成 加密后的PHP文件  $fpp1 = fopen('temp_'.$filename, 'w');  fwrite($fpp1, $s) or die('写文件错误');   ?>

第三个方法

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实现源代码加密的方法


  • 上一条:
    php打开本地exe程序,js打开本地exe应用程序,并传递相关参数方法
    下一条:
    php 替换文章中的图片路径,下载图片到本地服务器的方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客