php实现php代码的加密解密,php加密文件如何解密

发布时间:2022-11-18

本文目录一览:

  1. php代码加密怎么解密?
  2. 请教php源码加密及解密问题
  3. PHP常用加密解密方法
  4. 如何对PHP文件进行加密

php代码加密怎么解密?

$key = "This is supposed to be a secret key !!!";
function keyED($txt, $encrypt_key)
{
    $encrypt_key = md5($encrypt_key);
    $ctr = 0;
    $tmp = "";
    for ($i = 0; $i < strlen($txt); $i++) {
        if ($ctr == strlen($encrypt_key)) $ctr = 0;
        $tmp .= substr($txt, $i, 1) ^ substr($encrypt_key, $ctr, 1);
        $ctr++;
    }
    return $tmp;
}
function encrypt($txt, $key)
{
    srand((double)microtime() * 1000000);
    $encrypt_key = md5(rand(0, 32000));
    $ctr = 0;
    $tmp = "";
    for ($i = 0; $i < strlen($txt); $i++) {
        if ($ctr == strlen($encrypt_key)) $ctr = 0;
        $tmp .= substr($encrypt_key, $ctr, 1) .
            (substr($txt, $i, 1) ^ substr($encrypt_key, $ctr, 1));
        $ctr++;
    }
    return keyED($tmp, $key);
}
function decrypt($txt, $key)
{
    $txt = keyED($txt, $key);
    $tmp = "";
    for ($i = 0; $i < strlen($txt); $i++) {
        $md5 = substr($txt, $i, 1);
        $i++;
        $tmp .= (substr($txt, $i, 1) ^ $md5);
    }
    return $tmp;
}
$string = "Hello World !!!";
// encrypt $string, and store it in $enc_text
$enc_text = encrypt($string, $key);
// decrypt the encrypted text $enc_text, and store it in $dec_text
$dec_text = decrypt($enc_text, $key);
// 加密
function str2hex($s)
{
    $r = "";
    $hexes = array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f");
    for ($i = 0; $i < strlen($s); $i++) {
        $r .= ($hexes[(ord($s{$i}) >> 4)] . $hexes[(ord($s{$i}) & 0xf)]);
    }
    return $r;
}
// 解密
function hex2str($s)
{
    $r = "";
    for ($i = 0; $i < strlen($s); $i += 2) {
        $x1 = ord($s{$i});
        $x1 = ($x1 >= 48 && $x1 <= 58) ? $x1 - 48 : $x1 - 97 + 10;
        $x2 = ord($s{$i + 1});
        $x2 = ($x2 >= 48 && $x2 <= 58) ? $x2 - 48 : $x2 - 97 + 10;
        $r .= chr((($x1 << 4) & 0xf0) | ($x2 & 0x0f));
    }
    return $r;
}
echo str2hex("山东");
echo "\n";
echo hex2str("c9bdb6ab");

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

base64 可加可解。md5 不可解。 两种PHP的源码加密方式,此加密方法支持任意PHP版本。 注意,加密后的PHP代码无需第三方工具解密,像往常一样,直接运行即可。

<?php
function encode_file_contents($filename) {
    $type = strtolower(substr(strrchr($filename, '.'), 1));
    if ('php' == $type && is_file($filename) && is_writable($filename)) {
        $contents = file_get_contents($filename);
        $contents = php_strip_whitespace($filename);
        $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" . ' ?>';
// 生成 加密后的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;
    }
}
?>

使用方法参考如下:

// 加密过程
$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);
// 解密过程
$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常用加密解密方法

作者/上善若水

  1. md5(string $str,bool $flag = false);
    • $flag = false 默认返回32位的16进至数据散列值
    • $flag = true 返回原始流数据
  2. sha1($string,$flag = false)
    • $flag = false 默认返回40位的16进至数据散列值
    • true 返回原始流数据
  3. hash(string $algo,srting $str,bool $flag);
    • $algo : 算法名称,可通过hash_algos()函数获取所有hash加密的算法
    • 如:md5sha1等,采用md5sha1加密所得结果和1、2两种方式结果相同。
    • $flag = false 默认返回16进至的数据散列值,具体长度根据算法不同而不同。
    • true 返回原始流数据。
  4. crypt(string $str,$string $salt);
    • 函数返回使用 DES、Blowfish 或 MD5 算法加密的字符串。
    • 具体算法依赖于PHP检查之后支持的算法和salt的格式和长度,当然具体结果也和操作系统有关。比较结果采用 hash_equals($crypted, crypt($input, $salt));且salt值相同。
    • Password_verify($str, $crypted);
  5. password_hash ( string $str, integer $algo [, array $options ] )
    • 函数返回哈希加密后的密码字符串,password_hash()crypt()的一个简单封装
    • $algo : 算法 PASSWORD_DEFAULTPASSWORD_BCRYPT
    • $options = [
      • "cost"=10,//指明算法递归的层数
      • "salt"="xxadasdsad"//加密盐值,即将被遗弃,采用系统自动随机生成安全性更高
      • ];
    • 使用的算法、cost 和盐值作为哈希的一部分返回
    • Password_verify($str, $hashed);
  6. base64_encode(string $str)
    • 设计此种编码是为了使二进制数据可以通过非纯 8-bit 的传输层传输,例如电子邮件的主体。base64_decode(string $encoded)可以进行解码。
  7. mcrypt_encrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )
    • mcrypt_decrypt ( string $cipher , string $key , string $crypted , string $mode [, string $iv ] )
    • $cipher: 加密算法,mcrypt_list_algorithms()可以获取该函数所有支持的算法,如MCRYPT_DES("des")MCRYPT_RIJNDAEL_128("rijndael-128");
    • $mode : 加密模式,mcrypt_list_modes()获取所有支持的加密模式,ecbcbc
    • $key: 加密的秘钥,mcrypt_get_key_size ( string $cipher , string $mode )获取指定的算法和模式所需的密钥长度。$key要满足这个长度,如果长度无效会报出警告。
    • $iv : 加密的初始向量,可通过mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] )
      • Iv的参数size:通过mcrypt_get_iv_size ( string $cipher , string $mode )获取
      • Iv的参数source:初始向量数据来源。可选值有:MCRYPT_RAND(系统随机数生成器),MCRYPT_DEV_RANDOM(从/dev/random文件读取数据)和MCRYPT_DEV_URANDOM(从/dev/urandom文件读取数据)。在 Windows 平台,PHP 5.3.0 之前的版本中,仅支持MCRYPT_RAND
      • 注意:在 PHP 5.6.0 之前的版本中,此参数的默认值为MCRYPT_DEV_RANDOM
      • 注意:如果没有更多可用的用来产生随机数据的信息,那么MCRYPT_DEV_RANDOM可能进入阻塞状态。
  8. $data : 要加密的字符串数据

如何对PHP文件进行加密

Zend Guard是目前市面上最成熟的PHP源码加密产品。 经过本人搜集资料,亲身测试后,总结了如何利用Zend Guard对PHP文件进行加密,以及如何利用Zend Loader对加密后的PHP文件进行解密。 我使用的是Wampserver2.2,其中php的版本是5.3.10。(注意:这个里面自带的php版本属于TS版本,即Thread safety线程安全)

Zend Guard的安装及破解

点击下载 Zend Guard5.5.0,下载完成后,请自行傻瓜式安装。 破解需要注意以下几点:

  1. 本KEY的有效时间为2010年7月10号,因此激活时,请将自己电脑的系统时间调整到这个时间之前,如:2009-01-01
  2. 本KEY激活的为试用版,加密过的文件只有14天有效时间,因此在加密文件时,请将自己电脑的系统时间向后调整几年,如:2020-01-01
  3. 点击下载授权文件 zend_guard授权文件.zip,解压得到zend_guard.zl,即激活用的文件
  4. 打开Zend Guard 5.5.0,[Help] - [Register] - [Search for a license file on my disk],选择zend_guard.zl授权文件激活即可

如何使用Zend Guard进行加密?

  1. 打开Zend Guard 5.5.0,[File]-[New]-[Zend Guard Project],新建项目。
  2. 点击 Next,下一步。弹出如下对话框,选择要进行加密的源文件或文件夹。
  3. 接下来是选择PHP的版本[与你web服务器上PHP的版本相对照],这里很重要,版本不对会出错,[Finish]完成项目的创建。
  4. 在Zend Guard左侧的Guard Explorer中,可以看到你新建的项目了,鼠标选中项目名称后,右键单击[Encode Project],完成。 如此,就实现了对PHP源码的最简单的加密。 我们可以在产品的输出目录(D:\productDir)里,看到加密后的文件。 可以看出,产品输出目录里的PHP文件已被加密了。 这种最简单的加密方式,我们并没有设置加密的有效期,也没有设置许可证支持(即解密时,是否需要许可证文件),默认是永不过期,不需要解密许可文件。 如果要设置解密时的许可证文件,可以点击 项目名称(project_test),再点击 项目主窗口中的 Overview 旁边的 Security 选项卡,就可以进行更加安全的加密设置了。

Zend Loader 解密

上面我们已经对PHP代码进行了最简单的加密(编码),加密后生成的PHP源代码,就不能再被web服务器上的PHP模块解析了。 当我们将加密后的php文件放到web服务器上执行时,会显示如下信息:

Zend Guard Run-time support missing!
One more more files on this web site were encoded by ZendGuard and the required run-time support is not installed or properly configured.

原来,加密后的php代码需要ZendGuardLoader模块才能正常运行。 因为我的php版本是5.3.10的,所以我这里只提供了ZendGuardLoader-php-5.3-Windows,如果是其他版本的php,请自行百度。 点击下载 ZendGuardLoader-php-5.3-Windows 下载后,解压压缩包,找到目录里的 ZendLoader.dll 文件,将它复制到你的php目录里的ext目录(PHP的扩展库目录)下,再编辑PHP的配置文件php.ini,添加如下代码:

[Zend.loader]
zend_loader.enable=1
zend_loader.disable_licensing=1
zend_loader.obfuscation_level_support=3
zend_loader.license_path=
zend_extension="d:\wamp\bin\php\php5.3.10\ext\ZendLoader.dll"

注:

  • zend_loader.enable 表示是否启用zend loader,1表示启用,0表示禁用
  • zend_loader.disable_licensing 表示是否禁用许可证,1表示禁用,0表示不禁用(由于上面我加密php文件的时候,没有设置许可证支持,故解密时,禁用许可证)
  • zend_loader.obfuscation_level_support 表示代码混淆级别
  • zend_loader.license_path 指定许可证文件的路径
  • zend_extension 指定zend loader 扩展文件 的路径 配置完成后,重启wampserver,如果您的php的版本是NTS(非线程安全的话),就可以正常执行加密后的PHP文件了。 但是,多数情况下的php版本都是TS(线程安全)的,比如,我这个wampserver集成环境中的php是php-5.3.10-ts,它是没有办法支持Zend Guard Loader扩展文件的。故还会报出上面的错误提示信息。 因为,Zend Guard Loader 只能支持 NTS版本的php,终极解决办法是下载安装 NTS 版本的php。 为了实现PHP源文件的 Zend 解密测试,可以下载安装 php-5.3.29-nts-Win32-VC9-x86,再来配置 Zend Loader 扩展支持。 如何查看安装好的PHP的版本及PHP是否已经成功支持Zend Loader? 通过查看 phpinfo() 函数的输出信息,利用 Ctrl + F 快速查找关键字Thread Safety 和 Zend Guard Loader。 如本人安装好php-5.3.29-nts版本的php后,phpinfo()的输出信息如下: 可以看到,Thread Safety 对应的值为disabled,就说明该php的版本是 NTS (非线程安全)的,否则就是TS版本的。 输出信息中,还可以看到 Zend Guard Loader v3.3 字样,说明 Zend Guard Loader 也安装成功了。 再往下面看,还可以查看 Zend Guard Loader 的配置信息,如下: 到此,整个 Zend Guard 加密和 Zend Guard Loader 解密,就介绍完毕了。 温馨提示: 为了顺利实现PHP代码的zend加密和解密,建议使用PHP官网上主流的PHP的NTS版和Zend官网上对应的Zend Guard加密软件、 Zend Guard Loader解密插件。 相关附件:
  • Wampserver2.2
  • Zend Guard5.5.0
  • php-5.3.29-nts-Win32-VC9-x86
  • mod_fcgid-2.3.6-win32-x86.zip