swoolephp加密_PHP中给源代码加密的几种方法

商业使用推荐 Swoole Compiler 代码加密

以下是如何通过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,'');

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

?>

方法二

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 = '';

//echo $s;

// 生成 加密后的PHP文件

$fpp1 = fopen('temp_'.$filename, 'w');

fwrite($fpp1, $s) or die('写文件错误');

?>

加密方法三

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, "qq52o.me");

$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, "qq52o.me");

$filename = S_ROOT . './456.php';

file_put_contents($filename, $str);

该方法可以对文本的内容进行 二进制加密 与 解密

以上几种方法各有各的优点和用处,选择使用

沈唁志,一个PHPer的成长之路!

任何个人或团体,未经允许禁止转载本文:《PHP中给源代码加密的几种方法》,谢谢合作!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/244275.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

将html保存为图片,html2canvas 将html代码转为图片并保存下来

html2canvas 将html代码转为图片并保存下来发布时间&#xff1a;2018-05-22 10:15,浏览次数&#xff1a;421, 标签&#xff1a;htmlcanvas只是测试了下&#xff0c;在 谷歌和360上都可以&#xff0c;但是在火狐和ie下面暂时没有效果&#xff0c;所以先做个小记录&#xff0c;等…

产品配件类目税目分类_我国消费税税目种类有哪些?

在日常生活中我们接触到的商品&#xff0c;比如&#xff1a;烟、酒、汽车、贵重首饰及珠宝玉石、鞭炮焰火等等&#xff0c;其实在法律上都是需要交纳消费税的&#xff0c;这也就导致了这些商品在不同区域存在不同的价格这一现象。那么&#xff0c;我国消费税税目种类有哪些呢?…

raid 物理盘缓存状态_服务器raid卡、磁盘缓存的配置策略

最近遇到不少因服务器异常断电&#xff0c;导致文件系统元数据等被破坏的问题&#xff0c;究其原因是磁盘缓存没有关闭。不再重复码字了&#xff0c;直接贴图&#xff1a;所以带raid卡、磁盘服务器环境的推荐配置为&#xff1a;1 商用环境&#xff0c;RAID一定要有超级电容&…

主管护士需要考计算机和英语吗,2020主管护师改为机考,一定要注意这些问题!...

原标题&#xff1a;2020主管护师改为机考&#xff0c;一定要注意这些问题&#xff01;中国卫生人才网官方通知已确定&#xff0c;2020年护理学中级既主管护师考试形式-推行机考。那么&#xff0c;人机对话考试怎么考&#xff0c;有什么注意事项&#xff0c;为考生整理如下&…

pythonflask configlist.py_Python+Flask.0004.FLASK配置管理之三种方式加载外部配置

简单介绍:说明: 复杂的项目需要配置各种环境,若设置少可直接硬编码,设置多的话可通过加载配置/加载文件/加载变量的方式来设置123app.config.update(DEBUGTrue,)扩展: app.config是flask.config.Config类的实例,继承子PY内置数据结构dict,所以可以使用如上update方法,支持传入多…

html引用c 变量,在jsp页面中定义全局变量,供其他页面引用

一、在一个jsp中引用另一个jsp的方法有&#xff1a;1.使用 jsp include指令(常用)&#xff1a;file属性是必填的(绝对或相对路径)&#xff0c;但它不支持任何的表达式&#xff0c;也不允许通过&#xff1f;挂参方式来传递参数。注意&#xff1a;一般页面的top和bottom固定的时候…

bootstraptable控制分页_bootstrap table分页(前后端两种方式实现)

bootstrap table分页的两种方式&#xff1a;前端分页&#xff1a;一次性从数据库查询所有的数据&#xff0c;在前端进行分页(数据量小的时候或者逻辑处理不复杂的话可以使用前端分页)服务器分页&#xff1a;每次只查询当前页面加载所需要的那几条数据bootstrap 下载地址&#x…

gitlab 构建tag_GitLab常用命令 分支 Tag 配置 操作

一、从SVN迁出到本地Git仓库(还没有配置Git仓库的&#xff0c;直接看第八条)git svn clone "" ##注意路径需要双引号引起来二、在远程仓库中新建对应名称的项目http://git.xxx.cn (公司的gitlab地址)三、将远程仓库项目与本地仓库代码做好映射1. 建立…

html表单赋值提交,jQuery自动给表单赋值

/** jquery 初始化form插件&#xff0c;传入一个json对象&#xff0c;为form赋值* version: 1.0.0-2013.06.24* requires jQuery v1.5 or later* Copyright (c) 2013* note: 1、此方法能赋值一般所有表单&#xff0c;但考虑到checkbox的赋值难度&#xff0c;以及表单中很少用ch…

html5 hgroup,HTML5 hgroup 标签

实例HTML5 使用 对标题进行组合&#xff1a;Welcome to my WWFFor a living planetThe rest of the content...尝试一下 浏览器支持IE 9、Firefox、Opera、Chrome 和 Safari 支持 标签。注释&#xff1a;IE 8 或更早版本的 IE 浏览器不支持 标签。标签定义及使用说明标签被用来…

easyexcel和poi对比_POI 和 EasyExcel

POI 和 easyExcel 讲解转自狂神老师&#xff0c;仅作为个人笔记使用一、POI常用进程1、将用户信息导出为excel表格(导出数据....)2、将Excel表中的信息录入到网站数据库(习题上传....)开发中经常会设计到excel的处理&#xff0c;如导出Excel&#xff0c;导入Excel到数据库中&am…

python类定义学生信息_Python学生信息管理系统(注释最详细,小白都看的懂)

1 importos23 #学生系统基本功能4 #增删查改56 #如何实现该系统7 #1.显示系统功能界面8 #2.让用户选择功能9 #3.判断用户选择的指定功能&#xff0c;然后完成相应的操作(增删查改)1011 #面向对象分析12 #1.抽象类13 #学生系统管理类 学生类14 #2.分析类的成员1516 #学生系统管理…

git 拉取远端仓库_git 从远程仓库拉取代码

使用git 直接提交的话 直接 push获取最新版本 有两种 拉取 和 获取 pull 和 fetchgit pull 从远程拉取最新版本 到本地 自动合并 merge git pull origin mastergit fetch 从远程获取最新版本 到本地 不会自动合并 merge git fetch origin maste…

人机接口要学哪些计算机语言,智能人机接口

智能人机接口一般又简称为智能接口&#xff0c;是为了建立和谐的人机交互环境&#xff0c;在和谐的条件下实现智能&#xff0c;以智能的目的实现和谐&#xff0c;使人与计算机之间的交互能够像人与人之间的交流一样自然、方便&#xff0c;它对于改善人机交互的友好性&#xff0…

layer中嵌套的页面如何操作父页面_layui框架中layer父子页面交互详细解说

本文主要介绍了layui框架中layer父子页面交互的方法,结合实例形式分析了layer父子页面交互的常用技巧以及layer弹出多个iframe找到父页面的操作方法,需要的朋友可以参考下&#xff0c;希望给大家的学习有所启发。本文实例讲述了layui框架中layer父子页面交互的方法。分享给大家…

jquery获取html代码怎么写,jQuery从html代码中获取对应标签的写法

1、示例代码获取id为t1标签$(#t1)2、示例代码获取div标签$(.t2)3、示例代码dagagagragagdagagagragag获取所有的p标签$(p)4、示例代码获取id为tt的标签和p标签以及span标签$("#tt p span")注意空格的用法5、示例代码如果找找到该代码中所有的t5标签和span标签以及a标…

html5 canvas实际应用,Html5 Canvas入门及经典应用

Html5 Canvas入门及经典应用时间&#xff1a;2019-02-15 来源&#xff1a;华清远见canvas想必对于前端的工程师都不陌生了&#xff0c;它是 HTML5 新增的「画布」元素&#xff0c;是HTML5 的一大亮点&#xff0c;canvas翻译过来其实就是画布的意思&#xff0c;它可以替代fl…

redminote8自动关机怎么回事_红米Note8Pro手机值得入手吗 红米Note8Pro手机全面评测...

六、续航&#xff1a;4500mAh大电池与G90T的碰撞发手机发布之前&#xff0c;Redmi品牌总经理卢伟冰在微博上也说过&#xff0c;G90T的12nm处理器在功耗方面和7nm处理器会有10%左右的差距。为了弥补功耗的差距&#xff0c;红米Note 8 Pro采用了4500mAh的大电池。大电池和12nm芯碰…

计算机机房用户不规则行为,网络及网管机房管理理论练习

一、填空题&#xff1a;&#xff11;、机房行为管理的宗旨是( 以人为本)。&#xff12;、机房管理的内涵构架上至少应包括“(环境)、人、(机)、网络和管理”五个方面。&#xff13;、对于从事机房管理的工作人员&#xff0c;不仅要学会管理(机房设备)&#xff0c;也得学会管理(…