Слепой админ

Хакер, номер #020, стр. 020-056-1

[mal@xakep.ru]

[админ слепой не потому, что плохо видит,

а потому, что не знает, куда смотреть]

Начнем с того, что ты порутил сервак зло-админа.

На следующий день ты, довольный своим достижением, лезешь

на "свою" тачку: вводишь login, password... А она, нехорошая,

ругается, понимаешь ли: "Login incorrect".

Проверяешь мыло, а там мессага от root@zlo.org, прочтя которую,

тебе становится ясно, что просекли хацкера админы. -)

Ну и в голове, естественно, мысли:

- Да задолбали!! Черт... Как же сделать так, чтоб

в следующий раз меня не просекли?

Ну так вот, слушай, что я тебе скажу. В сети полно

программ - руткитов. Специально для таких, как ты. -) Они

позволяют тебе использовать систему после ее взлома так,

что администратор не замечает явных признаков твоего

присутствия. Правда, существует небольшая проблемка:

каждая такая программа переписана под определенную версию

ос. Поэтому не всегда получается найти то, что тебе нужно.

Ну что ж тут поделаешь... выход один: научиться писать

руткиты самому. -)

Руткит - набор определенных программ, выполняющих

системные функции, переписанных "под себя". К таким прогам

относятся : login, su, passwd, ps, who, ifconfig и другие.

Ну, не будем затягивать, приступаем... -) Итак,

первым делом переписывать будем login, с такой целью, чтобы

иметь доступ к системе по своему паролю, который не будет

светиться в базе данных пользователей, а конкретней - в

/etc/shadow. Короче говоря, у нас будет некий пароль,

с помощью которого можно будет залогиниться на тачку под

любым юзверем.

Да, кстати, все примеры, рассмотренные в этой статье,

реализовывались на FreeBSD 3.1. Поэтому если у тебя другой

*nix или другая версия freeBSD, возможны некоторые различия.

В общем, поехали... Чтобы переписать программу, нам желательно

достать ее исходники, а то изобретать колесо заново меня не

прет. -) Достать их можно в сети, а можно и прямо на машине,

если, устанавливая BSD, админ там не забыл указать установку

sources. -)

bash#whereis login.c

login: /usr/bin/login /usr/share/man/man1/login.1.gz /usr/src/usr.bin/login

bash#

Отлично. Вот и видно, что исходники login-a лежат у нас в папке

/usr/src/usr.bin/login/

Топаем туда.

Теперь нужно немного разобраться с этим логином. Что это, вообще,

за прога? -) Все очень просто. Когда ты телнетишься на тачку, запускается

login и требует от тебя логин с паролем, сверяет их с базой данных и решает

уже, дать тебе шелл или не дать. -) Ну так вот... Нам, по идее, нужно

найти в исходнике функцию, которая запрашивает пароль и сверяет его

с тем, что в базе. Найти ее довольно-таки просто.

Для этого нам, кстати, понадобится дебаггер. Я всегда использую - gdb.

Итак, нам надо дебагнуть логин, для этого сначала его нужно

откомпилить с определенным флагом -g3.

Поэтому для начала подправим немного Makefile.

bash#ee Makefile

И в ту строчку, что начинается с CFLAGS+= ,

добавим -g3, теперь она выглядит у меня так:

CFLAGS+=-g3 -Wall -DLOGIN_ACCESS -DLOGALL

Сохраняем Makefile и пишем:

bash#make

После того как login откомпилится, запускаем дебаггер gdb.

bash#gdb login

Содержание  Вперед на стр. 020-056-2

Выпуски журнала "Xakep"
Журнал Хакер. Содержание номера #001Журнал Хакер. Содержание номера #002Журнал Хакер. Содержание номера #003Журнал Хакер. Содержание номера #004Журнал Хакер. Содержание номера #005Журнал Хакер. Содержание номера #006Журнал Хакер. Содержание номера #007Журнал Хакер. Содержание номера #008Журнал Хакер. Содержание номера #009Журнал Хакер. Содержание номера #010Журнал Хакер. Содержание номера #011Журнал Хакер. Содержание номера #012Журнал Хакер. Содержание номера #013Журнал Хакер. Содержание номера #014Журнал Хакер. Содержание номера #015Журнал Хакер. Содержание номера #016Журнал Хакер. Содержание номера #017Журнал Хакер. Содержание номера #018Журнал Хакер. Содержание номера #019Журнал Хакер. Содержание номера #020Журнал Хакер. Содержание номера #021Журнал Хакер. Содержание номера #022Журнал Хакер. Содержание номера #023Журнал Хакер. Содержание номера #024Журнал Хакер. Содержание номера #025Журнал Хакер. Содержание номера #026Журнал Хакер. Содержание номера #027Журнал Хакер. Содержание номера #028Журнал Хакер. Содержание номера #029Журнал Хакер. Содержание номера #030Журнал Хакер. Содержание номера #031Журнал Хакер. Содержание номера #032Журнал Хакер. Содержание номера #033Журнал Хакер. Содержание номера #034Журнал Хакер. Содержание номера #035Журнал Хакер. Содержание номера #036Журнал Хакер. Содержание номера #037Журнал Хакер. Содержание номера #038Журнал Хакер. Содержание номера #039Журнал Хакер. Содержание номера #040Журнал Хакер. Содержание номера #041Журнал Хакер. Содержание номера #042Журнал Хакер. Содержание номера #043Журнал Хакер. Содержание номера #044Журнал Хакер. Содержание номера #045Журнал Хакер. Содержание номера #046Журнал Хакер. Содержание номера #047Журнал Хакер. Содержание номера #048Журнал Хакер. Содержание номера #049Журнал Хакер. Содержание номера #050Журнал Хакер. Содержание номера #051Журнал Хакер. Содержание номера #052Журнал Хакер. Содержание номера #053Журнал Хакер. Содержание номера #054Журнал Хакер. Содержание номера #055Журнал Хакер. Содержание номера #056Журнал Хакер. Содержание номера #057Журнал Хакер. Содержание номера #058Журнал Хакер. Содержание номера #059Журнал Хакер. Содержание номера #060Журнал Хакер. Содержание номера #061Журнал Хакер. Содержание номера #062Журнал Хакер. Содержание номера #063Журнал Хакер. Содержание номера #064Журнал Хакер. Содержание номера #065Журнал Хакер. Содержание номера #066Журнал Хакер. Содержание номера #067Журнал Хакер. Содержание номера #068Журнал Хакер. Содержание номера #069Журнал Хакер. Содержание номера #070Журнал Хакер. Содержание номера #071Журнал Хакер. Содержание номера #072Журнал Хакер. Содержание номера #073Журнал Хакер. Содержание номера #074Журнал Хакер. Содержание номера #075Журнал Хакер. Содержание номера #076Журнал Хакер. Содержание номера #077Журнал Хакер. Содержание номера #078Журнал Хакер. Содержание номера #079Журнал Хакер. Содержание номера #080Журнал Хакер. Содержание номера #081Журнал Хакер. Содержание номера #082Журнал Хакер. Содержание номера #083Журнал Хакер. Содержание номера #084Журнал Хакер. Содержание номера #085Журнал Хакер. Содержание номера #086Журнал Хакер. Содержание номера #087Журнал Хакер. Содержание номера #088Журнал Хакер. Содержание номера #089Журнал Хакер. Содержание номера #090Журнал Хакер. Содержание номера #091Журнал Хакер. Содержание номера #092Журнал Хакер. Содержание номера #093Журнал Хакер. Содержание номера #094Журнал Хакер. Содержание номера #095Журнал Хакер. Содержание номера #096Журнал Хакер. Содержание номера #097Журнал Хакер. Содержание номера #098Журнал Хакер. Содержание номера #099Журнал Хакер. Содержание номера #100Журнал Хакер. Содержание номера #101Журнал Хакер. Содержание номера #102Журнал Хакер. Содержание номера #103Журнал Хакер. Содержание номера #104Журнал Хакер. Содержание номера #105Журнал Хакер. Содержание номера #106Журнал Хакер. Содержание номера #107Журнал Хакер. Содержание номера #108Журнал Хакер. Содержание номера #109Журнал Хакер. Содержание номера #110Журнал Хакер. Содержание номера #111Журнал Хакер. Содержание номера #112Журнал Хакер. Содержание номера #113Журнал Хакер. Содержание номера #114