网站/小程序/APP个性化定制开发,二开,改版等服务,加扣:8582-36016

    你们可能看到了趣模板最近发了几个基于帝国CMS开发的模板,都是些做了SEO优化处理的模板,最近又买了一个,但是在扫描后门的时候发现很多文件加密了,加密方式是phpjm加密

    查看更多关于 phpjm加密 的文章

    ,使用的时候是没问题的,但是为了查看是否有后门还是解密看看。


    在网上搜了下,发现大部分phpjm解密

    查看更多关于 phpjm解密 的文章

    的工具都是收费的,不过也不贵,但是想着以前也经常看到这种方式的加密文件,要不研究下有没有一劳永逸的解决phpjm加密方式的办法?于是在百度找到了这个免费phpjm解密

    查看更多关于 phpjm解密 的文章

    代码。

    使用方法就是通过浏览器运行此解密文件,然后就会会生成一个解密的php文件。

    < !--?php $file = 'phpjm.php'; //要解密的文件名 $fp = fopen($file, 'r'); $str = fread($fp, filesize($file)); fclose($fp); copy($file, '0_'.$file); $n = 1; while($n < 10){ $code = strdecode($str); if($n == 1){ $code = str_replace("__FILE__", "'0_$file'", $code); } $replace = '$decode'.$n.'=trim'; if(strpos($code, 'eval(') > 0){ $code = str_replace('eval(', $replace.'(', $code); }else{ preg_match("/@$(.*)($(.*),(.*)(/isU", $code, $res); $code = str_replace($res[3], "'$replace", $code); } $code = preg_replace('/$(.*)=false;(.*?)();/', '', $code); //上一版本 $code = preg_replace('/||@$(.*?)();/', '|| print("ok");', $code); $code = destr($code); $tmp_file = 'detmp'.$n.'.php'; file_put_contents($tmp_file, $code); include($tmp_file); $val = 'decode'.$n; $str = $$val; unlink($tmp_file); if(strpos($str, ';?-->') === 0){
    		$decode = $str;
    		break;
    	}
    	
    	$str = "< !--?phprn". $str; $n++; } $decode = preg_replace("/^(.*)exit('Access Denied'); /", "", $decode);
    file_put_contents($file.'.de.php' ,$decode);
    unlink('0_'.$file);
    echo 'done';
     
    ////////////
    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);
        return $code;
    }
     
    function fmt_code($code){
        global $vals,$funs;
        preg_match_all("/$[0-9a-zA-Z[]']+(,|;)/iesU", $code, $res);
        foreach($res[0] as $v){
            $val = str_replace(array('$',',',';'), '', $v);
            $deval = destr($val, 1);
            $vals[$val] = $deval;
            $code = val_replace($code, $val, $deval);
        }
     
        preg_match_all("/$[0-9a-zA-Z[]']+=/iesU", $code, $res);
        foreach($res[0] as $v){
            $val = str_replace(array('$','='), '', $v);
            $deval = destr($val, 1);
            $vals[$val] = $deval;
            $code = val_replace($code, $val, $deval);
        }
     
        preg_match_all("/functions[0-9a-zA-Z[]]+(/iesU", $code, $res);
        foreach($res[0] as $v){
            $val = str_replace(array('function ','('), '', $v);
            $deval = destr($val, 1);
            $funs[$val] = $deval;
            $code = str_replace('function '.$val.'(', 'function '.$deval.'(', $code);
            $code = str_replace('='.$val.'(', '='.$deval.'(', $code);
            $code = str_replace('return '.$val.'(', 'return '.$deval.'(', $code);
        }
        return $code;
    }
     
    function strdecode($str){
        $len = strlen($str);
        $newstr = '';
        for($i=0; $i 126 || $dec<32) && $dec<>13 && $dec<>10){
            return '['.$dec.']';
        }else{
            return chr($dec);
        }
    }
     
    function destr($str, $val=0){
        $k = 0;
        $num = '';
        $n = strlen($str);
        $code = '';
        for($i=0; $i


    评论 0

    暂无评论
    0
    0
    0
    立即
    投稿
    发表
    评论
    返回
    顶部