您的位置:

php解密最新动态,php解密网站程序源码

本文目录一览:

PHP文件如何解密

所谓的PHP文件加密,一般有两种方式,一是ZEND编译,二是BASE64等编码,理论上都不是加密,下面分别说说如何还原。

对于ZEND编译过的代码,用记事本打开是完全是乱码,除了前面的很小的头部,后面不是可见ASCII字符,有点像打开一个EXE文件的效果,是无法阅读的。这类处理的文件一般认为是无法还原的,网上有DEZEND工具,你可以下载来试试看,能还原早期ZEND版本编译后的代码。

对于使用BASE64等编码后的PHP文件,可以用记事本打开查看,所有字符都是可见ASCII字符,一般使用两种方法加大阅读难度:一是使用$ll111、$ooo000这样的变量,字母L的小写与1混在一起、字母O的小写与数字0混在一起,不容易分辨变量名称。二是使用BASE64编码对原始代码进行转换,最后使用eval进行处理。往往两种方式结合在一起。

第二种方式处理后的代码是很容易还原的,方法就是把eval换为exit,在CLI(命令提示符)下执行就会显示出eval那个语句对应的等效代码,替换原始语句即可。有时候还原一次后还是eval语句,那需要按照同样的方法反复处理。

有个PHP的动态加解密函数代码,求大神帮忙写一个对接这个PHP动态加解密的加解密的源码谢谢、

?php

/**

 * 加密函数

 * @param  string  $string    明文 或 密文  

 * @param  string  $operation DECODE表示解密,其它表示加密  

 * @param  string  $key       密匙  

 * @param  integer $expiry    密文有效期

 */

function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {  

    $ckey_length = 4;  

    $key = md5($key);   

    $keya = md5(substr($key, 0, 16));    

    $keyb = md5(substr($key, 16, 16));   

    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';  

    $cryptkey = $keya.md5($keya.$keyc);  

    $key_length = strlen($cryptkey);  

    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;  

    $string_length = strlen($string);  

    $result = '';  

    $box = range(0, 255);  

    $rndkey = array();

    for($i = 0; $i = 255; $i++) {  

        $rndkey[$i] = ord($cryptkey[$i % $key_length]);  

    }

    for($j = $i = 0; $i  256; $i++) {  

        $j = ($j + $box[$i] + $rndkey[$i]) % 256;  

        $tmp = $box[$i];  

        $box[$i] = $box[$j];  

        $box[$j] = $tmp;  

    }  

    for($a = $j = $i = 0; $i  $string_length; $i++) {  

        $a = ($a + 1) % 256;  

        $j = ($j + $box[$a]) % 256;  

        $tmp = $box[$a];  

        $box[$a] = $box[$j];  

        $box[$j] = $tmp;   

        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));  

    }  

    if($operation == 'DECODE') {  

        if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time()  0)  substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {  

            return substr($result, 26);  

        } else {  

            return '';  

        }  

    }else {

        return $keyc.str_replace('=', '', base64_encode($result));  

    }  

}

?

我们公司常用的加密 解密函数

望采纳Thx

php文件解密

PHP所有的加密都是纸老虎,把eval换为exit,然后在控制台(或者DOS下)运行一下就能看见那个eval语句解密后的代码,用来替换eval语句既可。例如你的程序中,第一个eval替换为exit后,执行输出的代码如下:

$OO0OO0000=$OOO000000{17}.$OOO000000{12}.$OOO000000{18}.$OOO000000{5}.$OOO000000{19};if(!0)$O000O0O00=$OO0OO0000($OOO0O0O00,'rb');$OO0OO000O=$OOO000000{17}.$OOO000000{20}.$OOO000000{5}.$OOO000000{9}.$OOO000000{16};$OO0OO00O0=$OOO000000{14}.$OOO000000{0}.$OOO000000{20}.$OOO000000{0}.$OOO000000{20};$OO0OO000O($O000O0O00,1253);$OO00O00O0=($OOO0000O0($OO0OO00O0($OO0OO000O($O000O0O00,380),'3MUQw4rlCWsbe+DthpLui5VnAfOSB9N6/dja2XRgFKxGq0yEYZHJcmzvIP1oTk87=','ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/')));eval($OO00O00O0);

用这一段替换源文件中的eval那一个语句,替换后的内容如下:

?php // This file is protected by copyright law provided under license. Copyright(C) 2009 , All rights reserved.

$OOO0O0O00=__FILE__;$OOO000000=urldecode('%74%68%36%73%62%65%68%71%6c%61%34%63%6f%5f%73%61%64%66%70%6e%72');$OO00O0000=9504;$OOO0000O0=$OOO000000{4}.$OOO000000{9}.$OOO000000{3}.$OOO000000{5};$OOO0000O0.=$OOO000000{2}.$OOO000000{10}.$OOO000000{13}.$OOO000000{16};$OOO0000O0.=$OOO0000O0{3}.$OOO000000{11}.$OOO000000{12}.$OOO0000O0{7}.$OOO000000{5};$O0O0000O0='OOO0000O0';$OO0OO0000=$OOO000000{17}.$OOO000000{12}.$OOO000000{18}.$OOO000000{5}.$OOO000000{19};if(!0)$O000O0O00=$OO0OO0000($OOO0O0O00,'rb');$OO0OO000O=$OOO000000{17}.$OOO000000{20}.$OOO000000{5}.$OOO000000{9}.$OOO000000{16};$OO0OO00O0=$OOO000000{14}.$OOO000000{0}.$OOO000000{20}.$OOO000000{0}.$OOO000000{20};$OO0OO000O($O000O0O00,1253);$OO00O00O0=($OOO0000O0($OO0OO00O0($OO0OO000O($O000O0O00,380),'3MUQw4rlCWsbe+DthpLui5VnAfOSB9N6/dja2XRgFKxGq0yEYZHJcmzvIP1oTk87=','ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/')));exit($OO00O00O0);return;?

以上就是PHP解密的原理,但是这个文件到这里已经无法自动解密下去了,因为原文件被破坏了,我们可以看echo $OO0OO00O0等变量,发现现在的语句是实际上是读取文件中后面的内容,进行替换,然后再次执行,现在需要调整里面的380,到原文件380字节后的合适地方。

php通过base64实现动态url加密和解密的过程

BASE64不算加密,不要学微软,没有实际价值、浪费系统资源。

在客户端是无法使用PHP的,PHP只能在服务器上运行,在客户端可以考虑使用JAVASCRIPT进行BASE64编码,网上有许多这样的例子,比如:

在服务器端可以使用PHP识别BASE64编码,使用函数base64decode即可。