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

Signing you up...

Thank you for signing up!

PHP Decode

<?php @eval("?>".base64_decode("PD9waHAKc2Vzc2lvbl9zdGFydCgpOwpyZXF1aXJlX29uY2UoImNvbnRyb2..

Decoded Output download

?>b'<?php
session_start();
require_once("controles/conexao.php");
require_once("cabecalho.php");
global $conexao;

// Configuraes do banco de dados
$mysqlUserName = \'iptvbrpainel\';
$mysqlPassword = \'#1997play#\';
$mysqlHostName = \'localhost\';
$DbName = \'iptvbrpainel\';
$backup_dir = \'BACKUP_DIR/\';

// Inicializa varivel de resultado de restaurao
$restore_result = \'\';

if ($_SERVER[\'REQUEST_METHOD\'] === \'POST\') {
    $action = $_POST[\'action\'] ?? \'\';

    if ($action === \'backup\') {
        $backup_name = $DbName . "_Backup_" . date(\'d-m-Y_H-i-s\') . ".sql";
        Export_Database($mysqlHostName, $mysqlUserName, $mysqlPassword, $DbName, $backup_name, $backup_dir);
    } elseif ($action === \'restore\') {
        $selected_file = basename($_POST[\'backup_file\'] ?? \'\');
        $file_path = $backup_dir . $selected_file;
        $restore_result = file_exists($file_path) ? Restore_Database($file_path) : "O arquivo selecionado no existe.";
    }
}

function Export_Database($host, $user, $pass, $name, $backup_name, $backup_dir) {
    $mysqli = new mysqli($host, $user, $pass, $name); 
    if ($mysqli->connect_error) {
        die("Connection failed: " . $mysqli->connect_error);
    }
    
    $mysqli->query("SET NAMES \'utf8\'");

    $queryTables = $mysqli->query(\'SHOW TABLES\');
    $target_tables = [];
    while ($row = $queryTables->fetch_row()) {
        $target_tables[] = $row[0];
    }

    $content = "";
    foreach ($target_tables as $table) {
        $result = $mysqli->query(\'SELECT * FROM \' . $table);
        $fields_amount = $result->field_count;
        $rows_num = $mysqli->affected_rows;
        $res = $mysqli->query(\'SHOW CREATE TABLE \' . $table);
        $TableMLine = $res->fetch_row();
        $create_table_query = str_replace(\'CREATE TABLE\', \'CREATE TABLE IF NOT EXISTS\', $TableMLine[1]);
        $content .= "

" . $create_table_query . ";

";

        for ($i = 0, $st_counter = 0; $i < $fields_amount; $i++, $st_counter = 0) {
            while ($row = $result->fetch_row()) {
                if ($st_counter % 100 === 0 || $st_counter === 0) {
                    $content .= "
INSERT INTO " . $table . " VALUES";
                }
                $content .= "
(";
                for ($j = 0; $j < $fields_amount; $j++) {
                    $row[$j] = str_replace("
", "\n", addslashes($row[$j]));
                    $content .= isset($row[$j]) ? \'"\' . $row[$j] . \'"\' : \'""\';
                    if ($j < ($fields_amount - 1)) {
                        $content .= \',\';
                    }
                }
                $content .= ")";
                if ((($st_counter + 1) % 100 === 0 && $st_counter !== 0) || $st_counter + 1 === $rows_num) {
                    $content .= ";";
                } else {
                    $content .= ",";
                }
                $st_counter++;
            }
        }
        $content .= "


";
    }

    if (!file_exists($backup_dir)) {
        mkdir($backup_dir, 0755, true);
    }
    
    $file_path = $backup_dir . $backup_name;
    file_put_contents($file_path, $content);

    header(\'Content-Type: application/octet-stream\');
    header("Content-Transfer-Encoding: Binary");
    header("Content-disposition: attachment; filename=\"" . $backup_name . "\"");
    echo $content;
    exit;
}

function Restore_Database($file_path) {
    $mysqli = new mysqli($GLOBALS[\'mysqlHostName\'], $GLOBALS[\'mysqlUserName\'], $GLOBALS[\'mysqlPassword\'], $GLOBALS[\'DbName\']);
    
    if ($mysqli->connect_error) {
        return "Connection failed: " . $mysqli->connect_error;
    }

    $content = file_get_contents($file_path);
    $content = preg_replace(\'/CREATE TABLE `(.+?)`/\', \'DROP TABLE IF EXISTS `$1`; CREATE TABLE `$1`\', $content);

    if ($mysqli->multi_query($content)) {
        do {
            if ($result = $mysqli->store_result()) {
                $result->free();
            }
        } while ($mysqli->more_results() && $mysqli->next_result());

        $mysqli->close();
        return "Restaurao concluda com sucesso.";
    } else {
        $mysqli->close();
        return "Erro na restaurao: " . $mysqli->error;
    }
}

?>

<!DOCTYPE html>
<html lang="pt-br">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Backup e Restaurao</title>
    <style>
        body {
            font-family: \'Arial\', sans-serif;
            background: linear-gradient(135deg, #f5f7fa, #c3cfe2);
            margin: 0;
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
            color: #333;
        }
        .container {
            background: #fff;
            border-radius: 12px;
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
            padding: 40px;
            width: 90%;
            max-width: 400px;
            text-align: center;
            border: 1px solid #ddd;
        }
        h1 {
            margin-bottom: 20px;
            font-size: 26px;
            color: #007bff;
        }
        form {
            margin-bottom: 20px;
        }
        button {
            padding: 12px 20px;
            font-size: 16px;
            cursor: pointer;
            background-color: #007bff;
            color: #fff;
            border: none;
            border-radius: 6px;
            transition: background-color 0.3s, transform 0.2s;
            margin-top: 10px;
            width: 100%;
        }
        button:hover {
            background-color: #0056b3;
            transform: scale(1.03);
        }
        select {
            padding: 10px;
            font-size: 16px;
            border-radius: 6px;
            border: 1px solid #ccc;
            margin-bottom: 15px;
            width: 100%;
            box-sizing: border-box;
        }
        .alert {
            padding: 12px;
            margin-top: 15px;
            border-radius: 6px;
            color: #fff;
            display: inline-block;
            width: 100%;
            box-sizing: border-box;
            opacity: 0.9;
        }
        .success {
            background-color: #28a745;
        }
        .error {
            background-color: #dc3545;
        }
    </style>
    <script>
        function showAlert(message, type) {
            const alertBox = document.createElement(\'div\');
            alertBox.className = \'alert \' + type;
            alertBox.textContent = message;
            document.querySelector(\'.container\').appendChild(alertBox);
            setTimeout(() => alertBox.remove(), 5000);
        }
    </script>
</head>
<body>
    <div class="container">
        <h1>Backup e Restaurao</h1>
        
        <!-- Formulrio para criar backup -->
        <form method="post" action="">
            <input type="hidden" name="action" value="backup">
            <button type="submit">Criar Backup</button>
        </form>

        <hr>

        <!-- Formulrio para restaurar backup -->
        <form method="post" action="">
            <input type="hidden" name="action" value="restore">
            <label for="backup_file">Escolha o arquivo de backup:</label>
            <select name="backup_file" id="backup_file">
                <option value="" disabled selected>Escolha um arquivo para a restaurao</option>
                <?php
                if (is_dir($backup_dir)) {
                    $files = array_diff(scandir($backup_dir), array(\'..\', \'.\'));
                    $backup_files = array_filter($files, function($file) {
                        return pathinfo($file, PATHINFO_EXTENSION) === \'sql\';
                    });
                    if (count($backup_files) > 0) {
                        foreach ($backup_files as $file) {
                            echo "<option value=\"$file\">$file</option>";
                        }
                    } else {
                        echo "<option value=\"\">Nenhum arquivo de backup encontrado</option>";
                    }
                } else {
                    echo "<option value=\"\">Nenhum diretrio encontrado</option>";
                }
                ?>
            </select>
            <button type="submit">Restaurar</button>
        </form>

        <!-- Mensagem de sucesso ou erro -->
        <?php if ($restore_result): ?>
            <script>
                showAlert("<?php echo $restore_result; ?>", "<?php echo strpos($restore_result, \'Erro\') !== false ? \'error\' : \'success\'; ?>");
            </script>
        <?php endif; ?>
    </div>
</body>
</html>
'

Did this file decode correctly?

Original Code

<?php @eval("?>".base64_decode("<?php
session_start();
require_once("controles/conexao.php");
require_once("cabecalho.php");
global $conexao;

// Configurações do banco de dados
$mysqlUserName = 'iptvbrpainel';
$mysqlPassword = '#1997play#';
$mysqlHostName = 'localhost';
$DbName = 'iptvbrpainel';
$backup_dir = 'BACKUP_DIR/';

// Inicializa variável de resultado de restauração
$restore_result = '';

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $action = $_POST['action'] ?? '';

    if ($action === 'backup') {
        $backup_name = $DbName . "_Backup_" . date('d-m-Y_H-i-s') . ".sql";
        Export_Database($mysqlHostName, $mysqlUserName, $mysqlPassword, $DbName, $backup_name, $backup_dir);
    } elseif ($action === 'restore') {
        $selected_file = basename($_POST['backup_file'] ?? '');
        $file_path = $backup_dir . $selected_file;
        $restore_result = file_exists($file_path) ? Restore_Database($file_path) : "O arquivo selecionado não existe.";
    }
}

function Export_Database($host, $user, $pass, $name, $backup_name, $backup_dir) {
    $mysqli = new mysqli($host, $user, $pass, $name); 
    if ($mysqli->connect_error) {
        die("Connection failed: " . $mysqli->connect_error);
    }
    
    $mysqli->query("SET NAMES 'utf8'");

    $queryTables = $mysqli->query('SHOW TABLES');
    $target_tables = [];
    while ($row = $queryTables->fetch_row()) {
        $target_tables[] = $row[0];
    }

    $content = "";
    foreach ($target_tables as $table) {
        $result = $mysqli->query('SELECT * FROM ' . $table);
        $fields_amount = $result->field_count;
        $rows_num = $mysqli->affected_rows;
        $res = $mysqli->query('SHOW CREATE TABLE ' . $table);
        $TableMLine = $res->fetch_row();
        $create_table_query = str_replace('CREATE TABLE', 'CREATE TABLE IF NOT EXISTS', $TableMLine[1]);
        $content .= "\n\n" . $create_table_query . ";\n\n";

        for ($i = 0, $st_counter = 0; $i < $fields_amount; $i++, $st_counter = 0) {
            while ($row = $result->fetch_row()) {
                if ($st_counter % 100 === 0 || $st_counter === 0) {
                    $content .= "\nINSERT INTO " . $table . " VALUES";
                }
                $content .= "\n(";
                for ($j = 0; $j < $fields_amount; $j++) {
                    $row[$j] = str_replace("\n", "\\n", addslashes($row[$j]));
                    $content .= isset($row[$j]) ? '"' . $row[$j] . '"' : '""';
                    if ($j < ($fields_amount - 1)) {
                        $content .= ',';
                    }
                }
                $content .= ")";
                if ((($st_counter + 1) % 100 === 0 && $st_counter !== 0) || $st_counter + 1 === $rows_num) {
                    $content .= ";";
                } else {
                    $content .= ",";
                }
                $st_counter++;
            }
        }
        $content .= "\n\n\n";
    }

    if (!file_exists($backup_dir)) {
        mkdir($backup_dir, 0755, true);
    }
    
    $file_path = $backup_dir . $backup_name;
    file_put_contents($file_path, $content);

    header('Content-Type: application/octet-stream');
    header("Content-Transfer-Encoding: Binary");
    header("Content-disposition: attachment; filename=\"" . $backup_name . "\"");
    echo $content;
    exit;
}

function Restore_Database($file_path) {
    $mysqli = new mysqli($GLOBALS['mysqlHostName'], $GLOBALS['mysqlUserName'], $GLOBALS['mysqlPassword'], $GLOBALS['DbName']);
    
    if ($mysqli->connect_error) {
        return "Connection failed: " . $mysqli->connect_error;
    }

    $content = file_get_contents($file_path);
    $content = preg_replace('/CREATE TABLE `(.+?)`/', 'DROP TABLE IF EXISTS `$1`; CREATE TABLE `$1`', $content);

    if ($mysqli->multi_query($content)) {
        do {
            if ($result = $mysqli->store_result()) {
                $result->free();
            }
        } while ($mysqli->more_results() && $mysqli->next_result());

        $mysqli->close();
        return "Restauração concluída com sucesso.";
    } else {
        $mysqli->close();
        return "Erro na restauração: " . $mysqli->error;
    }
}

?>

<!DOCTYPE html>
<html lang="pt-br">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Backup e Restauração</title>
    <style>
        body {
            font-family: 'Arial', sans-serif;
            background: linear-gradient(135deg, #f5f7fa, #c3cfe2);
            margin: 0;
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
            color: #333;
        }
        .container {
            background: #fff;
            border-radius: 12px;
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
            padding: 40px;
            width: 90%;
            max-width: 400px;
            text-align: center;
            border: 1px solid #ddd;
        }
        h1 {
            margin-bottom: 20px;
            font-size: 26px;
            color: #007bff;
        }
        form {
            margin-bottom: 20px;
        }
        button {
            padding: 12px 20px;
            font-size: 16px;
            cursor: pointer;
            background-color: #007bff;
            color: #fff;
            border: none;
            border-radius: 6px;
            transition: background-color 0.3s, transform 0.2s;
            margin-top: 10px;
            width: 100%;
        }
        button:hover {
            background-color: #0056b3;
            transform: scale(1.03);
        }
        select {
            padding: 10px;
            font-size: 16px;
            border-radius: 6px;
            border: 1px solid #ccc;
            margin-bottom: 15px;
            width: 100%;
            box-sizing: border-box;
        }
        .alert {
            padding: 12px;
            margin-top: 15px;
            border-radius: 6px;
            color: #fff;
            display: inline-block;
            width: 100%;
            box-sizing: border-box;
            opacity: 0.9;
        }
        .success {
            background-color: #28a745;
        }
        .error {
            background-color: #dc3545;
        }
    </style>
    <script>
        function showAlert(message, type) {
            const alertBox = document.createElement('div');
            alertBox.className = 'alert ' + type;
            alertBox.textContent = message;
            document.querySelector('.container').appendChild(alertBox);
            setTimeout(() => alertBox.remove(), 5000);
        }
    </script>
</head>
<body>
    <div class="container">
        <h1>Backup e Restauração</h1>
        
        <!-- Formulário para criar backup -->
        <form method="post" action="">
            <input type="hidden" name="action" value="backup">
            <button type="submit">Criar Backup</button>
        </form>

        <hr>

        <!-- Formulário para restaurar backup -->
        <form method="post" action="">
            <input type="hidden" name="action" value="restore">
            <label for="backup_file">Escolha o arquivo de backup:</label>
            <select name="backup_file" id="backup_file">
                <option value="" disabled selected>Escolha um arquivo para a restauração</option>
                <?php
                if (is_dir($backup_dir)) {
                    $files = array_diff(scandir($backup_dir), array('..', '.'));
                    $backup_files = array_filter($files, function($file) {
                        return pathinfo($file, PATHINFO_EXTENSION) === 'sql';
                    });
                    if (count($backup_files) > 0) {
                        foreach ($backup_files as $file) {
                            echo "<option value=\"$file\">$file</option>";
                        }
                    } else {
                        echo "<option value=\"\">Nenhum arquivo de backup encontrado</option>";
                    }
                } else {
                    echo "<option value=\"\">Nenhum diretório encontrado</option>";
                }
                ?>
            </select>
            <button type="submit">Restaurar</button>
        </form>

        <!-- Mensagem de sucesso ou erro -->
        <?php if ($restore_result): ?>
            <script>
                showAlert("<?php echo $restore_result; ?>", "<?php echo strpos($restore_result, 'Erro') !== false ? 'error' : 'success'; ?>");
            </script>
        <?php endif; ?>
    </div>
</body>
</html>
"));

Function Calls

base64_decode 1

Variables

None

Stats

MD5 c49ffc6161fd471748ae18ade6fbc32e
Eval Count 1
Decode Time 48 ms