чем разобрать exe файл

ResourcesExtract — утилита для распаковки файлов EXE, DLL, OCX и CPL

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

И сполняемые файлы EXE и DLL по своей сути являются архивами или лучше сказать контейнерами, способными хранить в себе различные типы данных, а не только один программный код. В свою очередь это означает, что подобно другим архивам файлы EXE также могут быть распакованы. Правда, обычные архиваторы здесь не помогут, для распаковки этого типа контейнеров нужны специальные утилиты, например, такие как ResourcesExtract.

Эта маленькая, легкая и очень простая утилита прекрасно справляется с распаковкой файлов. В отличие от профессиональных редакторов ресурсов, обычно используемых программистами и позволяющих «вытаскивать» их исполняемых файлов элементы по отдельности, ResourcesExtract работает как примерно так же как обычный архиватор. Она автоматически перебирает файлы в специальной папке, после чего извлекает данные в указанном пользователем месте.

Программа имеет простой и удобный пользовательский интерфейс, представленный одним единственным окном. Установки экстрактор не требует и может запускаться с любого переносного носителя. Утилита позволяет извлекать иконки, статические и анимированные курсоры, видео в AVI формате, файлы карт, манифестов, документы HTML и некоторые другие типы файлов. Что именно должна искать утилита, можно указать непосредственно в рабочем окне.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Из дополнительных возможностей приложения стоит упомянуть обработку вложенных директорий (глубина поиска указывается отдельно), конвертирование файлов карт в формат PNG, перезапись исходных элементов. Чтобы распаковать файл, нужно указать к нему путь, задать директорию для сохранения результатов и нажать кнопку старта. После того как элементы будут извлечены, утилита автоматически откроет содержащую их папку.

Опытные пользователи могут запускать приложение в режиме командной строки, выполнять пакетное сканирование файлов. В целом со своей работой данный экстрактор справляется неплохо, в то же время ResourcesExtract несколько уступает Universal Extractor — другой популярной программе для распаковки контейнеров. Распространяется ResourcesExtract бесплатно, рекламы программа не содержит, совместима с ОС Windows 7, 8 и 8.1. Язык интерфейса — английский.

Источник

Чем открыть exe? Как распаковать EXE-файл в Windows и Mac

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл
Программа для редактирования exe файлов, которая поставляется с поддержкой создания резервных копий и пакетного экспорта. Она позволяет просмотр, замену, добавление, удаление и извлечение ресурсов, расположенных в 32-разрядных и 64-разрядных исполняемых файлах Windows и файлах ресурсов (*.res).

Исполняемые файлы Windows (или, более конкретно, файлы Win32 PE) часто содержат небольшую базу данных ресурсов: графические файлы, текстовые строки, значки и другие программные атрибуты. Часто может оказаться полезным изменить эти ресурсы, например, изменить внешний вид программы или исправить неправильный перевод в таблице строк. Anolis Resourcer предназначена для изменения ресурсов исполняемых файлов.

Способ первый: традиционная распаковка

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Традиционная распаковка не требует установленных в системе вспомогательных программ. Все, что нужно, — уже предустановлено в Windows.

Итак, процесс распаковки EXE-файла следующий:

Вам остается лишь дождаться завершения этого процесса, после чего можно будет закрывать окно Мастера установок. Вот так просто можно распаковывать EXE-файлы программы.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Какие файлы не имеет смысла открывать в редакторе ресурсов

Не смотря на то, что Resource Tuner предназначен для открытия и редактирования любых 32-/64-битных исполняемых файлов, существуют некоторые виды EXE файлов, в которых ресурсы практически отсутствуют.

1. Файлы, созданные при помощи Visual Basic.

В таких файлах в секции ресурсов ничего нет, кроме иконы и информации о версии. Строчки и диалоги в программах, написанных на визуальном бейсике, хранятся в своём собственном закрытом формате, и стандартная секция ресурсов в них не используется.

Поскольку Resource Tuner — это 32-битная программа, существуют естественные ограничения для размещения образа открываемого файла в виртуальной памяти в пределах первого гигабайта. Файл размером в гигабайт и более туда просто не поместится.

3. Самораспаковывающиеся архивы в виде EXE файлов.

В таких файлах в ресурсах ничего нет, кроме иконы и информации о версии, а может и этого не быть. По сути, это архивированные данные, снабжённые подпрограммой для распаковки.

4. Инсталляторы других программ.

Resource Tuner работает на всех версиях Windows

от 2000 и XP до 8 и 10.

Минимальные системные требования:

Процессор Intel Pentium® или AMD K5 166 MHz 16 MB RAM

Copyright © 2020 Heaventools Software. Все права сохранены.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Динамически подключаемая библиотека или DLL выполняет роль своеобразного исполняемого файла, который многократно используется различными приложениями для осуществления действий. Такое решение позволяет экономить дисковое пространство в несколько раз, а также происходит эффективная организация памяти. Из этого выходит, что на компьютере каждого пользователя хранится множество DLL-объектов, которые можно открыть и не только просмотреть, но и отредактировать.

Способ второй: извлечение установочных файлов

Второй метод кардинально отличается от первого. Если в первом случае нужно было распаковать файлы программы для того, чтобы после этого запустить ее на компьютере, то в этом случае нужно извлечь файлы самого инсталлятора, чтобы произвести с ними манипуляции. В примере представлена специальная программа под названием ResourcesExtract. Работает она следующим образом:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

В итоге в указанной вами папке будут находиться файлы установщика. Вы сможете отредактировать их в любое время.

PE-Explorer

Под первым номером идет довольно распространенный редактор PE-Explorer. В отличие от своего собрата Resource Tuner, он способен редактировать не только ресурсы приложения, но и код. Несмотря на свой почтенный возраст, исправно работает даже в Windows 10. К сожалению, PE-Explorer умеет работать только с 32-битными файлами и при попытке открыть 64-битный бинарник сообщает об ошибке.

Утилита обладает богатой функциональностью: отображает все элементы заголовка РЕ, определяет, к каким DLL происходит обращение, предсказывает поведение программ и логику взаимодействия с другими модулями и даже открывает запакованные UPX, UPack или NSPack файлы. Кроме того, она позволяет просматривать и редактировать секции PE-файла, исследовать содержимое таблиц импорта и экспорта и проверять наличие и целостность цифровой подписи. В качестве «вишенки на торте» тут присутствует полноценный дизассемблер.

Но это только на словах, а на деле мы его сейчас проверим. Из-за того что продукт платный, я использовал триальную версию, готовую работать на протяжении 30 дней. Об урезанных функциях ничего сказано не было.

Запустим редактор и сразу же откроем наше подопытное приложение. PE-Explorer первым делом выводит информацию о заголовке PE-файла. Для получения сведений об остальных разделах достаточно пощелкать кнопки на панели инструментов. Жмем пиктограмму Disassembler и открываем окно для выбора поддерживаемых инструкций: SSE, SSE2 и прочее. Указываем необходимые и начинаем процесс нажатием кнопки Start Now.

В открывшемся окне большую часть занимает область с дизассемблерным листингом, чуть ниже располагается шестнадцатеричный дамп. Если в заголовке нижней панели выбрать вкладку Strings, то отобразятся все строки в исследуемом приложении. Так что поиском можно найти и эталонный пароль. Однако для этого пришлось бы перебрать весь внушительный список доступных строк, так что отложим этот вариант до худших времен.

Так как мы с помощью отладчика нашли адрес инструкции, которая отвечает за ход выполнения программы, то попробуем проверить этот адрес в PE-Explorer: нажимаем Ctrl-F (или Search → Find) и вводим адрес для поиска: 402801.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Что ж, я немного разочарован результатом дизассемблирования. Даже отладчик в этом месте показывает мне инструкцию test, а здесь я вижу лишь начало ее шестнадцатеричного кода: 0х85. При этом я не могу редактировать код! Зачем мне все эти возможности, если утилита не позволяет делать самую базовую вещь?

Я даже не могу списать этот недочет на ограничения демоверсии, так как о ее отличиях от платной ничего толком не сказано. Допускаю, что с теми целями, для которых этот продукт предназначен (статическое изучение приложения и вектора его выполнения), он справляется хорошо. Однако нашим требованиям программа не соответствует, поэтому смело вычеркиваю PE-Explorer из списка кандидатов.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Как распаковать EXE-файлы на Mac

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Распаковка в операционной системе Mac происходит совсем другим способом. Для того, чтобы достать сами файлы с EXE, вы можете использовать простой архиватор. Принцип распаковки такой же, как и с архивами. В статье показано, как распаковать EXE-файлы, чтобы после запустить программу на компьютере. Именно таким образом вы можете запускать программы Windows в операционной системе Mac.

Итак, для того, чтобы произвести заявленные действия, вам необходимо выполнить следующее:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

После этого вы без проблем сможете запускать файл EXE. Далее запустится инсталлятор, а дальнейшие действия аналогичны тем, что были в Windows.

Ошибки при открытии файла

Если при открытии файла возникает ошибка, то скорее всего по трём причинам: файл защищён, файл 16-битный, или это вообще не исполняемый файл.

1. Ошибка: Файл повреждён, сжат упаковщиком или защищён протектором.

Вероятность того, что файл сжат для уменьшения размера, весьма велика. Упаковщиков и протекторов для исполняемых файлов существует не один десяток, и всё время появляются новые. Resource Tuner поддерживает распаковку только одного, зато самого распостранённого упаковщика — UPX. Остальные упаковщики не поддерживаются, и вам придётся самостоятельно заниматься распаковкой файла, прежде чем вы сможете открыть файл для просмотра или редактирования.

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

Восстановление запуска exe вручную

Вручную действие будет немного сложнее, но зато не требует установки или загрузки программ, подойдёт для компьютера вне сети. Действия будут выполняться в реестре, поэтому не меняйте лишних параметров, так как это может плачевно сказаться на устойчивости системы.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

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

Также следует знать, что существуют тяжелые варианты проблемы, когда даже строка «Выполнить» не работает. Тогда нажмите Ctrl+Alt+Del, затем выберите «Файл» и «Выполнить».

Особенности работы с DLL файлами и возможные проблемы

Некоторые DLL не удастся не только изменить, но даже открыть. Это происходит с защищенными библиотеками и проблема не решается без специальных программ для взлома.

Пользователи также сталкиваются с отсутствием библиотек, необходимых для работы некоторых программ. ОС при этом выдает сообщение о том, что «файл не найден». Для устранения неисправности требуется отыскать недостающие DLL с помощью поисковых систем и скачать. Затем – поместить в требуемую папку.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

В редких случаях библиотеки DLL придется зарегистрировать в ОС:

Источник

Битва потрошителей. Выбираем лучший редактор для вскрытия исполняемых файлов Windows

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Содержание статьи

Так как мы в основном исследуем исполняемые файлы и динамические библиотеки для Windows, я брал только те РЕ-редакторы, которые работают в этой ОС. Если какой-то из инструментов поддерживает другие операционные системы и их исполняемые файлы (например, ELF), то это только плюс, но в данном случае для нас особого значения не имеет.

Мы будем выбирать утилиты на основе разумных и понятных факторов: функциональность, цена, удобство использования и частота обновления. Совсем старые решения, позволяющие редактировать бинарники для MS-DOS или Windows 9x, нам рассматривать ни к чему. Если какой-то из редакторов распространяется платно, то мы воспользуемся ознакомительной версией и отдельно отметим, какие функции в ней доступны. Но самый главный критерий будет состоять во взломе настоящего кракми.

PE-Explorer

Под первым номером идет довольно распространенный редактор PE-Explorer. В отличие от своего собрата Resource Tuner, он способен редактировать не только ресурсы приложения, но и код. Несмотря на свой почтенный возраст, исправно работает даже в Windows 10. К сожалению, PE-Explorer умеет работать только с 32-битными файлами и при попытке открыть 64-битный бинарник сообщает об ошибке.

Утилита обладает богатой функциональностью: отображает все элементы заголовка РЕ, определяет, к каким DLL происходит обращение, предсказывает поведение программ и логику взаимодействия с другими модулями и даже открывает запакованные UPX, UPack или NSPack файлы. Кроме того, она позволяет просматривать и редактировать секции PE-файла, исследовать содержимое таблиц импорта и экспорта и проверять наличие и целостность цифровой подписи. В качестве «вишенки на торте» тут присутствует полноценный дизассемблер.

Но это только на словах, а на деле мы его сейчас проверим. Из-за того что продукт платный, я использовал триальную версию, готовую работать на протяжении 30 дней. Об урезанных функциях ничего сказано не было.

В открывшемся окне большую часть занимает область с дизассемблерным листингом, чуть ниже располагается шестнадцатеричный дамп. Если в заголовке нижней панели выбрать вкладку Strings, то отобразятся все строки в исследуемом приложении. Так что поиском можно найти и эталонный пароль. Однако для этого пришлось бы перебрать весь внушительный список доступных строк, так что отложим этот вариант до худших времен.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Я даже не могу списать этот недочет на ограничения демоверсии, так как о ее отличиях от платной ничего толком не сказано. Допускаю, что с теми целями, для которых этот продукт предназначен (статическое изучение приложения и вектора его выполнения), он справляется хорошо. Однако нашим требованиям программа не соответствует, поэтому смело вычеркиваю PE-Explorer из списка кандидатов.

FlexHex

Думаю, нужно дать разработчику еще один шанс, поэтому рассмотрим другую утилиту Heaventools Software — hex-редактор FlexHex. Это инструмент для редактирования любых файлов, процессов или устройств в двоичном формате, ASCII и Unicode. По словам авторов, редактор умеет работать с файлами просто гигантского размера — 8 эксабайт. Кроме того, он поддерживает множество типов данных: байты, слова, двойные слова, восьмибитовые слова, различные десятичные значения со знаком и без, 32- и 64-битовые целые.

Сложные типы данных тут могут быть определены самим пользователем — это структуры, объединения, массивы, перечисления, строки и их сочетания. Обещают прямое редактирование любых значений, в том числе шестнадцатеричных, строковых, изменение областей памяти и типизированных данных. Поддерживаются битовые операции (NOT, AND, OR и XOR над блоками данных) и, конечно же, арифметические операции: сложение, вычитание, умножение, деление и взятие остатка.

Однако главная особенность FlexHex — это возможность сравнения файлов целиком или отдельными блоками. При этом использование карт сравнения позволяет сделать процесс более интуитивным и наглядным.

Все это хорошо, но как утилита справится со взломом — нашей элементарной задачкой? Отсутствие дизассемблера сразу намекает нам, что придется работать в hex-кодах. Запустим FlexHex и откроем с его помощью наш крякмис.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

В целом я бы не сказал, что этот редактор отличается значительным удобством и соответствует нюансам работы благородного крекера. Поэтому отдавать за него 60 долларов кровных лично я бы не стал.

Продолжение доступно только участникам

Вариант 1. Присоединись к сообществу «Xakep.ru», чтобы читать все материалы на сайте

Членство в сообществе в течение указанного срока откроет тебе доступ ко ВСЕМ материалам «Хакера», позволит скачивать выпуски в PDF, отключит рекламу на сайте и увеличит личную накопительную скидку! Подробнее

Вариант 2. Открой один материал

Заинтересовала статья, но нет возможности стать членом клуба «Xakep.ru»? Тогда этот вариант для тебя! Обрати внимание: этот способ подходит только для статей, опубликованных более двух месяцев назад.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Юрий Язев

Широко известен под псевдонимом yurembo. Программист, разработчик видеоигр, независимый исследователь. Старый автор журнала «Хакер».

Источник

Распаковка исполняемых файлов

Привет, хабровчане. В рамках курса «Reverse-Engineering. Basic» Александр Колесников (специалист по комплексной защите объектов информатизации) подготовил авторскую статью.

Также приглашаем всех желающих на открытый вебинар по теме «Эксплуатация уязвимостей в драйвере. Часть 1». Участники вебинара вместе с экспертом разберут уязвимости переполнения в драйверах и особенности разработки эксплойтов в режиме ядра.

Статья расскажет о подходах к анализу запакованных исполняемых файлов с помощью простых средств для обратной разработки. Будут рассмотрены некоторые пакеры, которые применяются для упаковки исполняемых файлов. Все примеры будут проведены в ОС Windows, однако изучаемые подходы можно легко портировать на любую ОС.

Инструментарий и настройка ОС

Для тестов будем использовать виртуальную машину под управлением ОС Windows. Инструментарий будет содержать следующие приложения:

установленный по умолчанию плагин x64dbg Scylla;

Самый быстрый и простой способ провести распаковку любого исполняемого файла — применить отладчик. Но так как мы будем также рассматривать язык программирования Python, то может понадобится проект:

uncompile6 проект, который позволяет разобрать байткод виртуальной машины Python;

pyinstallerExtractor инструмент для распаковки архива pyInstaller.

Общие методы снятия паковки

Разберемся, что же такое паковка. В большинстве случаев исполняемые файлы современных языков программирования имеют довольно большой размер при минимальном наборе функций. Чтобы оптимизировать данную величину, можно применить паковку или сжатие. Наиболее распространенный на сегодняшний день пакер — UPX. Ниже приведен пример того, как пакер проводит сжатие исполняемого файла.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

На картинке может показаться, что файл стал по размеру больше, однако это не всегда так. Большинство файлов за счет такой модификации могут уменьшить свой размер до 1.5 раз от исходного объема.

Что же от этого реверс-инженеру? Почему надо знать и уметь определять, что файл упакован? Приведу наглядный пример. Ниже приведен снимок файла, который не запакован:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

И файл, который был пропущен через алгоритм UPX:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Изменения коснулись в этом случае двух основных точек исполняемого файла:

Точка входа — в случае с упакованным файлом это начало алгоритма распаковки, настоящий алгоритм программы будет работать только после того, как будет распакован оригинальный файл;

Код оригинального файла: теперь не найти паттернов, которые можно сразу разбирать как команды.

Итак, чтобы снова анализировать оригинальный файл, нужно найти настоящую или оригинальную точку входа. Для этого нужно разбить алгоритм на основные этапы:

Этап подготовки исполнения файла — загрузчик ОС настраивает окружение, загружает файл в оперативную память;

Сохранение контекста — упаковщик сохраняет контекст исполнения файла (набор значений регистров общего назначения, которые были установлены загрузчиком ОС);

Распаковка оригинального файла;

Передача управления оригинальному файлу.

Пример UPX

Попробуем с помощью отладчика найти оригинальную точку входа для приложения. Запечатлим оригинальную точку входа до упаковки UPX:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Как та же точка входа выглядит после упаковки:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Запустим отладчик и попробуем найти место сохранения контекста:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Ждем первого использования ESP — в отладчике при этом значение регистра подсветится красным цветом. Затем устанавливаем точку останова на адрес и просто запускаем приложение:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

В результате попадаем на оригинальную точку входа:

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Вот так просто, теперь используя плагин Scylla Hide можно сохранить результирующий файл на жесткий диск и продолжить его анализ.

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

Пример PyInstaller

Не всегда подобный подход работает для приложений, которые используют более сложную структуру исполняемого файла. Рассмотрим файл, который был создан с помощью PyInstaller — пакет, который позволяет преобразовать Python скрипт в исполняемый файл. При генерации исполняемого файла создается архив, который содержит виртуальную машину Python и все необходимые библиотеки. Сам исходный код приложения при этом преобразуется в байт код и его нельзя дезассемблировать.

Попробуем все же получить что-то читаемое. Создадим простое приложение на Python и упакуем с помощью PyInstaller. Исходный код приложения:

Установим пакет pyInstaller и создадим exe файл:

Итак, проведем сбор информации о том, что в итоге получилось. У нас есть архив, который должен запустить виртуальную машину, и код, который мы записали в виде скрипта. Попробуем восстановить исходник и просто его прочесть даже без запуска.

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

чем разобрать exe файл. Смотреть фото чем разобрать exe файл. Смотреть картинку чем разобрать exe файл. Картинка про чем разобрать exe файл. Фото чем разобрать exe файл

Таким образом можно снова получить исходный код.

Смотреть открытый вебинар по теме «Эксплуатация уязвимостей в драйвере. Часть 1».

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *