Категория > Новости > Разведка змеем. Собираем информацию о системе с помощью Python - «Новости»
Разведка змеем. Собираем информацию о системе с помощью Python - «Новости»3-02-2021, 00:00. Автор: Емельян |
|
PyCharm. Установка и настройка просты как два рубля: скачал установщик, запустил — и кликай себе «Далее», пока есть такая кнопка. Еще нам потребуется Python. Я буду использовать версию 3.9.0 — с ней точно все работает. ЗадачиДавай сначала обрисуем, что мы вообще планируем делать. Я планирую собирать следующую информацию:
И отправляться это все будет прямиком тебе в телегу через специальный бот. Зачем?Наверняка у тебя возник вопрос: зачем может понадобиться MAC-адрес или модель процессора? Эти параметры меняются очень и очень редко, так что прекрасно подходят для фингерпринтинга. Даже если пользователь купит более быстрый интернет‑канал или поменяет часовой пояс, ты без особого труда сможешь определить, что уже имел дело с этим компьютером. Стоит помнить, что ровно такие же методы используют хитрые рекламщики для идентификации пользователей, да и разработчики триальных версий программ тоже. Эта статья поможет чуть лучше понять, что можно узнать о твоем компьютере в полностью автоматическом режиме, а как применить эту информацию — решать только тебе. В этой статье мы не будем показывать, как сформировать устойчивый к незначительным изменениям идентификатор, который поможет однозначно определить конкретный компьютер. Если тебе станет интересно — пиши в комментариях, и, возможно, мы сделаем большой гайд на эту тему! Создаем основу программыДля отправки данных я решил воспользоваться Telegram-ботом. Создать его ты можешь через BotFather, а после сохранить token твоего творения. Публиковать его нельзя — любой, кто получит этот токен, сможет захватить контроль над твоим ботом. Для подключения к Bot API «телеги» нужны всего две строчки: import telebotbot = telebot.TeleBot("token from BotFather") # Подключение ботаЧтобы оценить быстродействие, можно написать еще пару строк. Весь дальнейший код расположим между ними. Описанное выше подключение бота уже вписано сюда. import telebotfrom datetime import datetimebot = telebot.TeleBot("token")start = datetime.now() # Начало отсчета# Сюда поместим нашу основу, поэтому оставляем местоends = datetime.now() # Конец отсчетаworkspeed = format(ends - start) # Вычисление времениТеперь перейдем собственно к сбору данных. Сбор данныхЯ не буду долго ходить вокруг да около и сразу начну разбирать секцию импорта. import getpassimport osimport socketfrom datetime import datetimefrom uuid import getnode as get_macimport pyautoguifrom speedtest import Speedtestimport telebotimport psutilimport platformfrom PIL import ImageТеперь кратко рассмотрим, что делает каждый модуль. Если какие‑то функции тебе не нужны, выброси строку импорта модуля и код, который использует этот модуль. Все просто! Итак, за работу с ОС и локальными ресурсами отвечают эти четыре модуля:
Этими модулями реализованы сетевые взаимодействия:
Служебные примочки, которые трудно отнести к категориям выше:
После этого нам требуется узнать основные стабильные характеристики системы: IP- и MAC-адреса, имя пользователя и ОС: name = getpass.getuser() # Имя пользователяip = socket.gethostbyname(socket.getfqdn()) # IP-адрес системыmac = get_mac() # MAC адресost = platform.uname() # Название операционной системыСтроки кода снабжены комментариями и в пояснениях не нуждаются. Скорость интернет-соединенияfrom speedtest import Speedtest # Импорт модуля. Рассматривался вышеinet = Speedtest()download = float(str(inet.download())[0:2] + "." # Входящая скорость+ str(round(inet.download(), 2))[1]) * 0.125uploads = float(str(inet.upload())[0:2] + "." # Исходящая скорость+ str(round(inet.download(), 2))[1]) * 0.125Скорость замеряется библиотекой сервиса Speedtest.net и, соответственно, выдает результат в мегабитах, а не мегабайтах. Чтобы это исправить, разделим численный результат на 8 или умножим на 0,125 — это одно и то же. Манипуляцию проделываем дважды — для входящей и исходящей скорости. Важно понимать, что замер не претендует на сверхточность, потому что мы никак не можем легко проверить, какую часть канала потребляют другие программы или даже другие устройства в сети. Если ты подключился к рабочей станции удаленно, твое соединение тоже что‑то будет потреблять. В программе поправка на это не реализована из‑за ее слишком низкой точности и трудоемкости. Часовой пояс и времяimport psutilzone = psutil.boot_time() # Узнает время, заданное на компьютереtime = datetime.fromtimestamp(zone) # Переводит данные в читаемый видЕсли ты настраиваешь чей‑то сервер или слишком удаленный компьютер, время может отличаться. Ко всем прочим данным добавим и показания часов — информация лишней не бывает. Если ты не знал, неправильно выставленное время и/или часовой пояс может вызывать сбои при подключении к сайтам, использующим HTTPS, а этот кусочек кода позволит легко выявить такие проблемы. Перейти обратно к новости |