$str = fread($fp, filesize($file));
$code = str_replace("__FILE__", "'0_$file'", $code);
$replace = '$decode'.$n.'=trim';
if(strpos($code, 'eval(') > 0){
$code = str_replace('eval(', $replace.'(', $code);
preg_match("/@\\$(.*)\(\\$(.*),(.*)\(/isU", $code, $res);
$code = str_replace($res[3], "'$replace", $code);
$code = preg_replace('/\\$(.*)=false;(.*?)\(\);/', '', $code);
$code = preg_replace('/\|\|@\\$(.*?)\(\);/', '|| print("ok");', $code);
$tmp_file = 'detmp'.$n.'.php';
file_put_contents($tmp_file, $code);
if(strpos($str, ';?>') === 0){
$str = "<?php\r\n". $str;
$decode = preg_replace("/^(.*)exit\('Access Denied'\); /", "<?php\r\n", $decode);
$del = strrchr($decode, 'unset');
$decode = str_replace($del, "\r\n?>", $decode);
file_put_contents($file.'.de.php' ,$decode);
function val_replace($code, $val, $deval){
$code = str_replace('$'.$val.',', '$'.$deval.',', $code);
$code = str_replace('$'.$val.';', '$'.$deval.';', $code);
$code = str_replace('$'.$val.'=', '$'.$deval.'=', $code);
$code = str_replace('$'.$val.'(', '$'.$deval.'(', $code);
$code = str_replace('$'.$val.')', '$'.$deval.')', $code);
$code = str_replace('$'.$val.'.', '$'.$deval.'.', $code);
$code = str_replace('$'.$val.'/', '$'.$deval.'/', $code);
$code = str_replace('$'.$val.'>', '$'.$deval.'>', $code);
$code = str_replace('$'.$val.'<', '$'.$deval.'<', $code);
$code = str_replace('$'.$val.'^', '$'.$deval.'^', $code);
$code = str_replace('$'.$val.'||', '$'.$deval.'||', $code);
$code = str_replace('($'.$val.' ', '($'.$deval.' ', $code);
function fmt_code($code){
preg_match_all("/\\$[0-9a-zA-Z\[\]']+(,|;)/iesU", $code, $res);
$val = str_replace(array('$',',',';'), '', $v);
$code = val_replace($code, $val, $deval);
preg_match_all("/\\$[0-9a-zA-Z\[\]']+=/iesU", $code, $res);
$val = str_replace(array('$','='), '', $v);
$code = val_replace($code, $val, $deval);
preg_match_all("/function\s[0-9a-zA-Z\[\]]+\(/iesU", $code, $res);
$val = str_replace(array('function ','('), '', $v);
$code = str_replace('function '.$val.'(', 'function '.$deval.'(', $code);
$code = str_replace('='.$val.'(', '='.$deval.'(', $code);
$code = str_replace('return '.$val.'(', 'return '.$deval.'(', $code);
function strdecode($str){
for($i=0; $i<$len; $i++){
if(($dec > 126 || $dec<32) && $dec<>13 && $dec<>10){
function destr($str, $val=0){
if($str[$i] == '[' && ($str[$i+1]==1 || $str[$i+1]==2)){
}elseif($str[$i] == ']' && $k==1){
$num = 97 + fmod($num, 25);
$str = fread($fp, filesize($file));
preg_match("/;(.*)\]='(.*?)';for\(/e", $code, $res);
preg_match("/;(.*)=(.*)\('(.*)'\);(.*);(.*)$/e", $res[1], $rs);
preg_match("/'\(@(.*?)\(\\\'(.*?)\\\'\)\)/e", $code, $res);
preg_match("/'\.(.*?)\.'/e", $c3, $r);
preg_match("/\('(.*?)','/e", $r[1], $r2);
$c4 = base64_decode(de1(destr($c4), 1));
$c3 = str_replace($r[0], $c4, $c3);
$funstr = gzuncompress(base64_decode($c3)).base64_decode($c1);
preg_match("/if(.*),'(.*?)'\)\)/e", $funstr, $res);
preg_match("/'\(@(.*)\(\\\'(.*?)\\\'\.\(/e", $code, $res);
preg_match("/'\.(.*?)\.'/e", $c, $r);
preg_match("/\('(.*?)','/e", $r[1], $r2);
$c6 = base64_decode(de1(destr($r2[1]), 1));
$c = str_replace($r[0], $c6, $c);
preg_match("/\"\.\((.*)='(.*?)'\)\);/e", $code, $res);
$decode = gzuncompress(base64_decode($c));
$str = explode('<!--<?php endif;?>', $decode);
$str = explode('?><?php $GLOBALS', $str[1]);
file_put_contents($file.'.de.php' ,$decode);
function de1($de1,$str2=''){
if(!$str2)return(base64_decode(destr($de1)));
for($i=0;$i<strlen($de1);$i++)
$s9.=ord($de1{$i})<245?((ord($de1{$i})>140&&ord($de1{$i})<245)?chr(ord($de1{$i})/2):$de1{$i}):"";
return(base64_decode($s9));
$de2=str_replace($c5,'',$de2);
$de2=str_replace($c5,'',$de2);
function strdecode($str){
for($i=0; $i<$len; $i++){
if(($dec > 126 || $dec<32)){
}elseif($str[$i] == ']'){