Последние записи
- Рандомное слайдшоу
- Событие для произвольной области внутри TImage
- Удаление папки с файлами
- Распечатка файла
- Преобразовать массив байт в вещественное число (single)
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
3rd
Янв
Поиск процедуры в исполняемом файле
Posted by maloy under Delphi, Архив
SoundMan
Уже несколько дней ломаю голову над реализацией следующего:
Допустим есть процедура
procedure MsgBox;
begin
MessageBox(0, 'Hello world', 'ddd', mb_iconinformation + mb_ok);
end;
Мне нужно найти эту процедуру в уже скомпилированном экзешнике.
Я пробовал вставлять метки, а потом уже искать их:
procedure MsgBox;
begin
asm
db 'L_00_00_start'
end;
MessageBox(0, 'Hello world', 'ddd', mb_iconinformation + mb_ok);
asm
db 'L_00_00_end'
end;
end;
Но если посмотреть на это место через 16-тиричный редактор, то там будет не то, что мне нужно.
Как я понял, здесь хранятся строки, которые я использую в программе. Но как тогда найти саму процедуру?
Uberchel
Если надо вызвать эту процедуру из другой программы, то пишеться так
procedure MsgBox; stdCall;
begin
asm
db 'L_00_00_start'
end;
MessageBox(0, 'Hello world', 'ddd', mb_iconinformation + mb_ok);
asm
db 'L_00_00_end'
end;
end;
......
exports
MsgBox; name='MsgBox';
Serge_Bliznykov
SoundMan, ну, мне не совсем понятно, зачем Вам таких сложным и извращённым способом искать процедуру (или любой код), но Вам надо использовать ассемблерный код в качестве метки:
например, такая процедура:
asm
mov ax, 05455h
xor ax,ax
end;
MessageBox(0, 'Hello world', 'ddd', mb_iconinformation + mb_ok);
компилируется в такой набор байт
-.0043F154: 66B85554 mov ax,05455 ;"TU"
-.0043F158: 6631C0 xor ax,ax
-.0043F15B: 6A40 push 040
-.0043F15D: 6870F14300 push 00043F170 -----v (1)
-.0043F162: 6874F14300 push 00043F174 -----v (2)
-.0043F167: 6A00 push 000
-.0043F169: E85274FCFF call MessageBoxA ;user32.dll
и если искать 66 B8 55 54 66 31 C0 то однозначно найдёте свою «метку»…
разумеется, ассемблерную вставку я написал «наобум» — можете придумать свой фирменные наборчик байт 😉
тема на форуме от 2009 года
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)