Национальный цифровой ресурс Руконт - межотраслевая электронная библиотека (ЭБС) на базе технологии Контекстум (всего произведений: 605683)
Консорциум Контекстум Информационная технология сбора цифрового контента
Уважаемые СТУДЕНТЫ и СОТРУДНИКИ ВУЗов, использующие нашу ЭБС. Рекомендуем использовать новую версию сайта.

GHIDRA. Полное руководство (6000,00 руб.)

0   0
Первый авторКрис Игл
АвторыКара Нэнс
ИздательствоМ.: ДМК Пресс
Страниц752
ID809600
АннотацияПлатформа Ghidra, ставшая итогом более десяти лет работы в Агентстве национальной безопасности, была разработана для решения наиболее трудных задач обратной разработки (Reverse Engeneering – RE). После раскрытия исходного кода этого инструмента, ранее предназначавшегося только для служебного пользования, один из лучших в мире дизассемблеров и интуитивно понятных декомпиляторов оказался в руках всех специалистов, стоящих на страже кибербезопасности. Эта книга, рассчитанная равно на начинающих и опытных пользователей, поможет вам во всеоружии встретить задачу RE и анализировать файлы, как это делают профессионалы.
Кому рекомендованоЭта книга, рассчитанная равно на начинающих и опытных пользователей, поможет вам во всеоружии встретить задачу RE и анализировать файлы, как это делают профессионалы.
ISBN978-5-97060-942-2
УДК004.4
ББК32.97
Крис, И. . GHIDRA. Полное руководство / Н. . Кара; И. . Крис .— Москва : ДМК Пресс, 2022 .— 752 с. : ил. — ISBN 978-5-97060-942-2 .— URL: https://rucont.ru/efd/809600 (дата обращения: 05.02.2023)

Предпросмотр (выдержки из произведения)

GHIDRA._Полное_руководство.pdf
Стр.5
Стр.9
Стр.10
Стр.11
Стр.12
Стр.13
Стр.14
Стр.15
Стр.16
Стр.17
GHIDRA._Полное_руководство.pdf
УДК 004.4 ББК 32.97 И26 Игл К., Нэнс К. И26 GHIDRA. Полное руководство / пер. с анг. А. А. Слинкина. – М.: ДМК Пресс, 2022. – 750 с.: ил. ISBN 978-5-97060-942-2 Платформа Ghidra, ставшая итогом более десяти лет работы в Агентстве национальной безопасности, была разработана для решения наиболее трудных задач обратной разработки (Reverse Engeneering – RE). После раскрытия исходного кода этого инструмента, ранее предназначавшегося только для служебного пользования, один из лучших в мире дизассемблеров и интуитивно понятных декомпиляторов оказался в руках всех специалистов, стоящих на страже кибербезопасности. Эта книга, рассчитанная равно на начинающих и опытных пользователей, поможет вам во всеоружии встретить задачу RE и анализировать файлы, как это делают профессионалы. УДК 004.4 ББК 32.97 Title of English­language original: The Ghidra Book: The Definitive Guide, ISBN 9781718501027, published by No Starch Press Inc. 245 8th Street, San Francisco, California United States 94103. The Russian­Language 1st edition Copyright © 2020 by DMK Press Publishing under license by No Starch Press Inc. All rights reserved.” Все права защищены. Любая часть этой книги не может быть воспроизведена в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. ISBN 978­1­71850­102­7 (англ.) ISBN 978­5­97060­942­2 (рус.) © 2020 Chris Eagle and Kara Nance © Оформление, издание, перевод, ДМК Пресс, 2022
Стр.5
ОГЛАВЛЕНИЕ ЧАСТЬ I. ВВЕДЕНИЕ ................................................... 25 Глава 1. Введение в дизассемблирование ...............................................27 Теория дизассемблирования ......................................................................... 28 Что делает дизассемблер ............................................................................... 29 Зачем нужен дизассемблер ........................................................................... 30 Анализ вредоносного ПО ........................................................................... 31 Анализ на уязвимость ................................................................................ 31 Анализ интероперабельности ................................................................... 32 Проверка компилятора .............................................................................. 32 Отображение команд в процессе отладки ............................................... 33 Как работает дизассемблер ........................................................................... 33 Базовый алгоритм дизассемблирования ................................................. 33 Алгоритм линейной развертки ................................................................. 35 Алгоритм рекурсивного спуска ................................................................. 37 Резюме.............................................................................................................. 42 Глава 2. Обратная разработка и инструменты дизассемблирования ......................................................................................43 Средства классификации .............................................................................. 44 file ................................................................................................................. 44 PE Tools ........................................................................................................ 47 PEiD ............................................................................................................. 48 Обзорные инструменты .................................................................................. 49 nm ................................................................................................................. 49 ldd ................................................................................................................. 52 objdump ........................................................................................................ 55 otool .............................................................................................................. 56 dumpbin........................................................................................................ 56 c++filt ............................................................................................................ 57 Инструменты глубокой инспекции ........................................................................................................ 59 strings ........................................................................................................... 59 Дизассемблеры ........................................................................................... 61 Резюме.............................................................................................................. 63 Глава 3. Первое знакомство с Ghidra ........................................................65 Лицензионная политика Ghidra .................................................................. 66 Версии Ghidra ................................................................................................. 66 Ресурсы поддержки Ghidra ........................................................................... 66 Скачивание Ghidra ........................................................................................ 68 Установка Ghidra ............................................................................................ 68 Запуск Ghidra ............................................................................................. 70 Резюме.............................................................................................................. 71 8 Оглавление
Стр.9
ЧАСТЬ II. ОСНОВЫ ИСПОЛЬЗОВАНИЯ GHIDRA ..... 73 Глава 4. Начало работы с Ghidra ...............................................................75 Запуск Ghidra ................................................................................................ 75 Создание нового проекта ............................................................................... 77 Загрузка файла в Ghidra ........................................................................... 78 Использование простого двоичного загрузчика ..................................... 82 Анализ файлов в Ghidra ................................................................................ 84 Результаты автоматического анализа ..................................................... 88 Поведение рабочего стола во время начального анализа ......................... 89 Сохранение работы и выход ...................................................................... 90 Советы по организации рабочего стола Ghidra .......................................... 91 Резюме.............................................................................................................. 92 Глава 5. Отображение данных в Ghidra ...................................................93 Браузер кода ................................................................................................... 94 Окна браузера кода ........................................................................................ 97 Окно листинга........................................................................................... 100 Создание дополнительных окон дизассемблера ...................................... 105 Представление графа функции в Ghidra .................................................. 106 Окно деревьев программы ........................................................................... 112 Окно дерева символов .................................................................................. 113 Импортируемые объекты ......................................................................... 114 Экспортируемые объекты ........................................................................ 115 Функции .................................................................................................... 115 Метки ......................................................................................................... 116 Классы........................................................................................................ 116 Пространства имен ................................................................................... 117 Окно диспетчера типов данных .................................................................. 117 Окно консоли ................................................................................................. 118 Окно декомпилятора .................................................................................... 118 Другие окна Ghidra ...................................................................................... 121 Окно байтов ............................................................................................... 121 Окно определенных данных ....................................................................... 123 Окно определенных строк ........................................................................... 125 Окна таблицы символов и ссылок на символы ......................................... 126 Окно карты памяти ...................................................................................... 130 Окно графа вызовов функции ..................................................................... 131 Резюме............................................................................................................ 132 Глава 6. Дизассемблирование в Ghidra .................................................135 Навигация по листингу дизассемблера ..................................................... 136 Имена и метки .......................................................................................... 136 Навигация в Ghidra ..................................................................................... 137 Перейти к .................................................................................................. 139 История навигации .................................................................................. 139 Кадры стека ................................................................................................... 141 Механизмы вызова функций .................................................................. 141 Оглавление 9
Стр.10
Соглашения о вызове ............................................................................... 144 Дополнительные сведения о кадре стека .............................................. 150 Размещение локальных переменных .................................................... 151 Примеры кадров стека ............................................................................. 152 Представления стека в Ghidra .................................................................... 157 Анализ кадров стека в Ghidra ................................................................ 158 Кадры стека в листинге дизассемблера ................................................ 159 Анализ кадра стека с помощью декомпилятора ................................... 162 Локальные переменные как операнды ................................................. 164 Редактор кадра стека в Ghidra ............................................................... 165 Поиск .............................................................................................................. 168 Поиск по тексту программы .................................................................... 169 Поиск в памяти ......................................................................................... 171 Резюме............................................................................................................ 173 Глава 7. Управление дизассемблированием ........................................175 Манипулирование именами и метками .................................................... 176 Переименование параметров и локальных переменных .................... 177 Переименование меток ............................................................................ 182 Добавление новой метки ......................................................................... 183 Редактирование меток ............................................................................. 185 Удаление метки ........................................................................................ 187 Навигация по меткам .............................................................................. 187 Комментарии ................................................................................................ 187 Концевые комментарии ........................................................................... 189 Предварительные и заключительные комментарии ........................... 190 Вводные комментарии ............................................................................. 190 Повторяемые комментарии ..................................................................... 192 Комментарии для параметров и локальных переменных .................. 192 Аннотации ................................................................................................. 193 Базовые преобразования кода .................................................................... 194 Изменение параметров отображения кода ........................................... 194 Форматирование операндов команд ...................................................... 196 Манипулирование функциями .............................................................. 198 Преобразование данных в код (и наоборот) .......................................... 202 Основы преобразования данных ................................................................ 203 Задание типов данных............................................................................. 204 Работа со строками ................................................................................... 206 Определение массивов ............................................................................. 208 Резюме............................................................................................................ 209 Глава 8. Типы данных и структуры данных .........................................211 В чем смысл этих данных? .......................................................................... 212 Распознавание структур данных в коде .................................................... 215 Доступ к элементам массива ................................................................... 215 Доступ к полям структуры ...................................................................... 228 Массивы структур ..................................................................................... 234 Создание структур в Ghidra ........................................................................ 236 10 Оглавление
Стр.11
Создание новой структуры ...................................................................... 237 Редактирование полей структуры .......................................................... 240 Наложение структур ................................................................................ 242 Введение в обратную разработку кода на C++ ......................................... 244 Указатель this ........................................................................................... 245 Виртуальные функции и vf-таблицы ..................................................... 246 Жизненный цикл объекта ....................................................................... 251 Декорирование имен ................................................................................ 253 Идентификация типа во время выполнения ........................................ 254 Отношения наследования ....................................................................... 256 Справочные материалы по обратной разработке кода на C++ ........... 257 Резюме............................................................................................................ 258 Глава 9. Перекрестные ссылки .................................................................259 Базовые сведения о ссылках ....................................................................... 260 Перекрестные (обратные) ссылки........................................................... 261 Пример анализа ссылок .......................................................................... 265 Окна управления ссылками ........................................................................ 271 Окно перекрестных ссылок ..................................................................... 272 Ссылки на .................................................................................................. 273 Ссылки на символы .................................................................................. 273 Дополнительные способы работы со ссылками .................................... 274 Резюме............................................................................................................ 276 Глава 10. Графы .............................................................................................277 Простые блоки ............................................................................................... 278 Графы функций ............................................................................................ 279 Графы вызовов функций ............................................................................. 290 Деревья .......................................................................................................... 297 Резюме............................................................................................................ 297 ЧАСТЬ III. ПОСТАВИТЬ GHIDRA СЕБЕ НА СЛУЖБУ ..................................................... 299 Глава 11. Коллективная обратная разработка программ ................301 Коллективная работа ................................................................................... 302 Подготовка сервера Ghidra.......................................................................... 303 Разделяемые проекты .................................................................................. 307 Создание разделяемого проекта ............................................................. 307 Управление проектом .............................................................................. 310 Меню окна проекта ...................................................................................... 311 Меню File ................................................................................................... 311 Меню Edit ................................................................................................. 314 Меню Project .............................................................................................. 316 Репозиторий проекта.................................................................................... 319 Управление версиями .............................................................................. 321 Пример ....................................................................................................... 324 Резюме............................................................................................................ 330 Оглавление 11
Стр.12
Глава 12. Настройка Ghidra .......................................................................331 Браузер кода ................................................................................................. 332 Реорганизация окон ................................................................................. 332 Редактирование параметров инструментов .......................................... 334 Редактирование параметров инструмента ............................................ 337 Специальные средства редактирования для некоторых инструментов .................................................................. 338 Сохранение конфигурации браузера кода ............................................ 340 Окно проекта в Ghidra ................................................................................. 340 Меню Tools..................................................................................................... 346 Рабочие пространства .................................................................................. 352 Резюме............................................................................................................ 353 Глава 13. Расширение взгляда на мир Ghidra .....................................355 Импорт файлов ............................................................................................. 356 Анализаторы ................................................................................................. 359 Модели слов .................................................................................................. 360 Типы данных ................................................................................................. 362 Создание новых архивов типов данных ................................................ 365 Идентификаторы функций ......................................................................... 369 Плагин Function ID ...................................................................................... 371 Пример применения плагина Function ID: UPX .................................. 374 Пример применения плагина Function ID: профилирование статической библиотеки ............................................ 379 Резюме............................................................................................................ 385 Глава 14. Основы написания скриптов для Ghidra ............................387 Диспетчер скриптов ..................................................................................... 388 Окно диспетчера скриптов ...................................................................... 388 Панель инструментов диспетчера скриптов ......................................... 390 Разработка скриптов .................................................................................... 391 Написание скриптов на Java (не JavaScript!) ....................................... 391 Пример редактирования скрипта: поиск по регулярному выражению ................................................................... 393 Скрипты на Python................................................................................... 399 Поддержка других языков ...................................................................... 401 Введение в Ghidra API ................................................................................. 402 Интерфейс Address ................................................................................... 403 Интерфейс Symbol .................................................................................... 403 Интерфейс Reference ................................................................................ 403 Класс GhidraScript ................................................................................... 404 Функции манипулирования программой ............................................. 410 Класс Program ........................................................................................... 411 Интерфейс Function ................................................................................. 413 Интерфейс Instruction ............................................................................. 413 Примеры скриптов Ghidra ........................................................................... 414 Пример 1: перечисление функций ......................................................... 414 Пример 2: перечисление команд ............................................................ 415 12 Оглавление
Стр.13
Пример 3: перечисление перекрестных ссылок ................................... 416 Пример 4: нахождение вызовов функции ............................................. 417 Пример 5: эмуляция поведения языка ассемблера.............................. 419 Резюме............................................................................................................ 422 Глава 15. Eclipse и GhidraDev ...................................................................423 Eclipse ............................................................................................................ 423 Интеграция с Eclipse ................................................................................ 424 Запуск Eclipse ........................................................................................... 425 Редактирование скриптов в Eclipse ....................................................... 426 Меню GhidraDev ........................................................................................... 427 GhidraDevNew ....................................................................................... 428 Навигация в обозревателе пакетов ........................................................ 434 Пример: проект модуля анализатора ........................................................ 441 Шаг 1: постановка задачи ....................................................................... 443 Шаг 2: создать модуль в Eclipse .............................................................. 443 Шаг 3: написать анализатор ................................................................... 443 Шаг 4: протестировать анализатор в Eclipse ........................................ 451 Шаг 5: добавить анализатор в Ghidra.................................................... 451 Шаг 6: тестирование анализатора в Ghidra .......................................... 452 Резюме............................................................................................................ 455 Глава 16. Необслуживаемый режим Ghidra .........................................457 Приступая к работе ...................................................................................... 458 Шаг 1: запуск Ghidra ............................................................................... 459 Шаги 2 и 3: создать новый проект Ghidra в указанном месте ............ 459 Шаг 4: импортировать файл в проект .................................................... 460 Шаги 5 и 6: автоматический анализ файла, сохранение и выход ..... 460 Флаги и параметры .................................................................................. 465 Написание скриптов .................................................................................... 475 HeadlessSimpleROP .................................................................................. 475 Автоматизированное создание базы данных FidDb ............................. 480 Резюме............................................................................................................ 482 ЧАСТЬ IV. ДОПОЛНИТЕЛЬНЫЕ ТЕМЫ .................. 483 Глава 17. Загрузчики Ghidra .....................................................................485 Анализ неизвестного файла ........................................................................ 487 Загрузка PE-файла Windows вручную ...................................................... 488 Пример 1: модуль загрузчика SimpleShellcode......................................... 502 Шаг 0: шаг назад ...................................................................................... 503 Шаг 1: поставить задачу .......................................................................... 506 Шаг 2: создать модуль в Eclipse .............................................................. 507 Шаг 3: разработать загрузчик ................................................................. 507 Шаг 4: добавить загрузчик в Ghidra ...................................................... 514 Шаг 5: протестировать загрузчик в Ghidra ........................................... 515 Пример 2: простой загрузчик шелл-кода из исходных файлов .................................................................. 517 Оглавление 13
Стр.14
Обновление 1: изменить ответ на опрос импортера ............................. 518 Обновление 2: найти шелл-код в исходном коде .................................. 518 Обновление 3: преобразовать шелл-код в байтовые значения ........... 519 Обновление 4: загрузить преобразованный байтовый массив ........... 520 Результаты ................................................................................................ 520 Пример 3: простой загрузчик шелл-кода в формате ELF ................... 522 Организационные мероприятия............................................................. 523 Формат заголовков ELF ........................................................................... 524 Определение поддерживаемых спецификаций загрузки ................... 525 Загрузить содержимое файла в Ghidra ................................................. 527 Отформатировать байты данных и добавить точку входа .................. 528 Файлы определений языков ................................................................... 529 Opinion-файлы .......................................................................................... 530 Результаты ................................................................................................ 532 Резюме............................................................................................................ 535 Глава 18. Процессорные модули в Ghidra .............................................537 Знакомство с процессорным модулем Ghidra ........................................... 539 Процессорные модули в Eclipse .............................................................. 539 SLEIGH ...................................................................................................... 541 Руководства по процессорам ................................................................... 543 Модификация процессорного модуля Ghidra ........................................... 545 Постановка задачи ................................................................................... 547 Пример 1: добавление команды в процессорный модуль ................... 547 Пример 2: модификация команды в процессорном модуле ................ 556 Вариант 1: записать в EAX константу ................................................... 556 Пример 3: добавление регистра в процессорный модуль .................... 567 Резюме............................................................................................................ 570 Глава 19. Декомпилятор Ghidra ...............................................................571 Анализ с помощью декомпилятора ............................................................ 571 Параметры анализа ................................................................................. 572 Окно декомпилятора .................................................................................... 575 Пример 1: редактирование в окне декомпилятора .............................. 576 Пример 2: функции, не возвращающие управление ........................... 582 Пример 3: автоматизированное создание структуры .......................... 584 Резюме............................................................................................................ 590 Глава 20. Зависимость от компилятора .................................................591 Высокоуровневые конструкции .................................................................. 592 Предложения switch ................................................................................ 592 Пример: сравнение компиляторов gcc и Microsoft C/C++ .................... 599 Параметры компилятора ............................................................................. 602 Пример 1: оператор деления по модулю ............................................... 603 Пример 2: тернарный оператор .............................................................. 606 Пример 3: встраивание функций ........................................................... 608 Реализация зависящих от компилятора особенностей C++ .................... 610 Перегрузка функций ................................................................................ 611 Реализации RTTI ..................................................................................... 612 14 Оглавление
Стр.15
Нахождение функции main ........................................................................ 617 Пример 1: от _start к main с компилятором gcc для Linux x86-64 ..... 618 Пример 2: от _start к main с компилятором clang для FreeBSD x86-64 .................................................................................. 619 Пример 3: от _start к main с компилятором Microsoft’s C/C++ ........... 620 Резюме............................................................................................................ 621 ЧАСТЬ V. РЕАЛЬНЫЕ ПРИЛОЖЕНИЯ .................... 623 Глава 21. Анализ обфусцированного кода ............................................625 Противодействие обратной разработке ...................................................... 626 Обфускация ............................................................................................... 626 Методы противодействия статическому анализу ................................ 627 Обфускация импортированной функции .............................................. 643 Методы противодействия динамическому анализу ............................. 648 Статическая деобфускация двоичных файлов в Ghidra.......................... 654 Скриптовая деобфускация ...................................................................... 654 Эмуляторная деобфускация .................................................................... 661 Резюме............................................................................................................ 670 Глава 22. Изменение двоичного кода......................................................673 Планирование заплаты ............................................................................... 674 Поиск того, что нуждается в изменении .................................................... 675 Поиск в памяти ......................................................................................... 675 Поиск прямых ссылок .............................................................................. 676 Поиск командных паттернов .................................................................. 677 Поиск конкретных типов поведения ...................................................... 682 Наложение заплаты ..................................................................................... 683 Внесение простых изменений ................................................................. 683 Внесение нетривиальных изменений .................................................... 690 Экспорт файлов ............................................................................................ 694 Форматы экспорта из Ghidra .................................................................. 695 Двоичный формат экспорта .................................................................... 696 Экспорт с применением скрипта ............................................................ 697 Пример: латание двоичного файла ............................................................ 699 Резюме............................................................................................................ 703 Глава 23. Определение разности двоичных файлов и отслеживание версий ...............................................................................705 Разность двоичных файлов ......................................................................... 706 Инструмент Program Diff......................................................................... 708 Пример: объединение двух проанализированных файлов ................. 712 Сравнение функций .................................................................................. 717 Окно сравнения функций........................................................................ 717 Пример: сравнение криптографических функций ................................... 720 Отслеживание версий ................................................................................. 727 Концепции, относящиеся к отслеживанию версий .............................. 728 Резюме........................................................................................................... 730 Оглавление 15
Стр.16
Ghidra для пользователей IDA ..................................................................731 Основы ........................................................................................................... 731 Создание базы данных ............................................................................ 732 Основные окна и навигация ................................................................... 734 Дерево символов ....................................................................................... 737 Скрипты ......................................................................................................... 738 Резюме............................................................................................................ 738 Предметный указатель ................................................................................739
Стр.17

Облако ключевых слов *


* - вычисляется автоматически