好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

PHP代码在线加密系统 php代码加密工具 xend

很多站长朋友们都不太清楚PHP代码在线加密系统,今天小编就来给大家整理PHP代码在线加密系统,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 php源码怎么加密 2、 有没有免费的PHP代码加密工具? 3、 如何对PHP文件进行加密 4、 php7代码如何加密 5、 请教php源码加密及解密问题 6、 PHP代码加密工具 Xend - 专注于PHP加密与PHP代码保护 php源码怎么加密

一、无需任何PHP扩展的加密

此类加密的代表有 威盾PHP加密专家、PHP在线加密平台、PHP神盾 等。

此类加密都是以eval函数为核心,辅以各式各样的字符串混淆和各种小技巧,来达到加密目的(更准确的说,应该算是混淆)。下面以一个简单的hello world为例来说明此类加密的大体过程。

<?php

echo "hello world";

首先 ,我们把这段代码变为通过eval执行的

<?php

eval('echo "hello world";');

然后 ,我们再进行一些转换,比如说base64编码

<?php

eval(base64_decode('ZWNobyAiaGVsbG8gd29ybGQiOw=='));

就这样子,我们的第一个加密过的php代码新鲜出炉了。。。

上面这个例子非常非常简单,基本上任何有一点php语言基础甚至别的语言基础的人都能轻松的看懂并解密。因此,我们需要一些方法让这个加密至少看上去不是那么简单。

二、同时采用多种编码函数

除了刚才提到的base64,php还有许多内置的编码函数,例如urlencode、gzcompress等。把这些函数混合使用可以提高解密的复杂度(不是难度),此外还可以使用strtr来制定自己的编码规则。 使用变量来代替函数名 使用特定字符来命名变量

这儿所说的特定字符是一些极其相似的字符,如I和1,0和O。试想一下满屏都是O和0组成的变量,并且每一个的名字长度都在10个字符以上。。。 判断文件自身是否被修改

这个功能看似容易,对文件做一下摘要再进行下对比即可知道是否被修改了,但是如何才能在文件内把摘要嵌入进去呢?我没有找到完美的方案,但一个变通的方案还是很容易的。。。

<?php

$code = substr(file_get_contents(__FILE__), 0, -32);

$hash = substr(file_get_contents(__FILE__), -32);

if (md5($code) !== $hash) {

exit('file edited');

}

ACBC41F727E00F85BEB3440D751BB4E3

当然,你可以把这个校验字符串放在别的位置来提高破解的难度。有了这个,别人想破解你的程序可就得多费一点功夫了。。。

既然知道了原理,那解密自然也就非常简单了,总体来说就三步:

把eval替换为输出,比如echo 根据编码规则把字符串还原 如果文件未解密完全,从第一步开始继续

当然,实际上的解密过程并没有这么简单,比如说如果加密的时候使用了gzcompress,那得到的数据将会包含一些二进制数据,而采用一般的文本编辑器打开时这些数据都会显示为乱码,并且在保存时丢失部分数据。解决方法很简单也很麻烦,那就是使用二进制(16进制)方式打开、修改和保存。

有没有免费的PHP代码加密工具?

这个我不知道。

加密工具,我建议您使用超级加密3000试试。

超级加密3000采用国际上成熟的加密算法和安全快速的加密方法,可以有效保障数据安全!

具体操作方法:

1 下载安装超级加密3000。

2 然后在需要加密的文件上单击鼠标右键选择加密。

3 在弹出的文件加密窗口中设置文件加密密码就OK了。

如何对PHP文件进行加密

php加密平台自开通以来已加密了670367个php文件,总数据大小5823.04 MB2015-04-18更新:PHP在线加密Beta版支持命名空间加密,即php源码中有namespace的文件加密。2015-01-13维护:修复PHP5.5及以上php版本更好支持php加密(免费版已不更新,不修复)

php授权用户动态简化,只记录授权变化状态2014-12-09新增自定义授权错误信息提示(以前为白屏)2014-06-22新增支持heredoc和nowdoc语法结构的字符串2014-03-24修复部份代码中使用__FILE__不兼容的BUG2013-09-02修改:php免费加密后版权信息中增加中文声明2013-08-01新增功能:授权版可锁定php文件加密的文件名,php文件加密后不允许更改文件名。此功能配合锁定域名功能效果更佳。

修复:部份环境中获取不到服务器IP地址2013-06-20维护:常规更新维护,PHP加密代码小调整。2013-05-12修改:重写授权版的PHP加密算法,提高对代码的保护。2013-04-11调整:发现有个别用户使用我们免费的php加密平台对php源码加密后作为非法用途,因此把免费版对上传的php文件大小调整为50K。2013-03-11修改:为了加强付费授权版的使用安全,把免费版和付费授权版的算法分开处理。以后升级过程中主要针对付费授权版进行升级,免费版只做BUG修复处理。2013-02-01修改:免费版的版权信息中不再显示内核更新日期。

修改:编码加强混淆程度2013-01-07修改:php加密后的代码中去除“PHPJM_”标志性字符。

新增:先对php源码压缩后再加密,减小加密后的php文件大小

修复:php源代码中的php标签只有<?而没有?>时的BUG2012-12-11新增功能:授权版可锁定在某个日期段内运行,可将您的代码以试用方式进行发布。

修改:不再限制加密后的文件以.php为扩展名运行,支持以任何扩展名保存加密后的文件。

修复:自定义版权信息乱码BUG2012-11-14PHP在线加密平台上线2012-11-06完成PHP加密核心算法代码。

php7代码如何加密

我们先写出函数:

<?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 = 'result1.php';  

encode_file_contents($filename);

echo "OK,加密完成!";

?>

3

测试是否加密成功:文件名为result1.php,运行代码

4

运行成功。

请教php源码加密及解密问题

base64 可加可解。 md5 不可解

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加密,还有 搞的在线加密,只是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代码加密工具 Xend - 专注于PHP加密与PHP代码保护

Xend加密、Xend加密工具、phpxend加密

PHPXEND加密已实现在线加密

效果图:

关于PHP代码在线加密系统的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于PHP代码在线加密系统 php代码加密工具 xend的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did211316
更新时间:2023-05-03   阅读:163次

上一篇: 宝塔安装PHP指令 宝塔安装php8

下一篇:php单列工厂模式 php工厂模式和单例模式区别

相关资讯

最新资料更新

  • 1.如何知道php密码 php确认密码
  • 2.php单个会话内存 php会话保存数据的两种方式是
  • 3.php如何接收对象 php怎么接收json数据
  • 4.form居中显示php form居中显示
  • 5.php会做流控吗 php流程控制
  • 6.php大牛交流教程 php大神
  • 7.phpmysql框架 php框架yii
  • 8.php网站下载图片 网站的php文件下载
  • 9.php图片打不开 php打不开文件
  • 10.php扩展的路径 php常用扩展有哪些
  • 11.php接收tcp数据 php tcp udp
  • 12.jq读取php变量 php读取html内容
  • 13.手机文件php怎么打开 手机php格式文件怎么打开
  • 14.php赋值后改变 php变量赋值
  • 15.php可代替js吗 php可以代替js吗
  • 16.mac安装php扩展 mac系统安装php环境
  • 17.php输入日期表单 php输出日历表
  • 18.php匹配尖括号 括号匹配python代码
  • 19.php数据导出csv php导出大量数据
  • 20.最新php环境搭建 最新php环境搭建方案

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://www.haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]