Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "WinAPI";
Текущий архив: 2004.06.20;
Скачать: [xml.tar.bz2];

Вниз

ImportTable   Найти похожие ветки 

 
Gost1   (2004-05-12 12:46) [0]

type
  PImageImportByName = ^TImageImportByName;
  _IMAGE_IMPORT_BY_NAME=packed record
   HInst: Word;
   Name: Byte;
 end;
 TImageImportByName =_IMAGE_IMPORT_BY_NAME;

TThunk=packed record
case Integer of
0: (ForwarderString: PByte);
1: (thFunction: PDWORD);
2: (Ordinal: DWORD);
3: (AddressOfData: PImageImportByName);
end;

PImageThunkData=^TImageThunkData;
_IMAGE_THUNK_DATA=packed record
Thunk: TThunk;
end;
TImageThunkData=_IMAGE_THUNK_DATA;
IMAGE_THUNK_DATA=_IMAGE_THUNK_DATA;


 PImport := PImageImportDescriptor(DWord(PEHeader.OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_IMPORT].VirtualAddress) + DWord(ImageBase));
  while (PImport.Name > 0) do begin
   модули тут перебираются все ок!
   lstrcpyn(PChar(@buf), PChar(PImport.Name + ImageBase), 15);
   MessageBox(0, PChar(@buf), "", MB_OK);
   pThunk := PImageThunkData(ImageBase + DWord(PImport.FirstThunk));
   while (pThunk.Thunk.thFunction <> nil) do begin
скорее всего неверно - тут, как получить смешение на имя импортируемой ф-ии?
pImpName := PImageImportByName(DWord(pThunk.Thunk.AddressOfData) + ImageBase);
    lstrcpyn(PChar(@buf), PChar(pImpName.Name + ImageBase), 8);
    MessageBox(0, PChar(@buf), "", MB_OK);
    inc(pThunk);
   end;
  inc(PImport);
  end; {while name}

Поглядите, плзз на код. Я хочу перечислить все импортируемые ф-ии. Получаю указатель на PImageThunkData, потом в цикле до нулевой секции на PImageImportByName, но вот тут скорее всего и есть оишибка, как правильно получить этот указатель? Используемые record"ы приведены!


 
Digitman ©   (2004-05-12 13:27) [1]

после того как в ран-тайм импортируемый модуль был загружен и присоединен к импортирующему модулю, значение поля pThunk.Thunk.thFunction содержит не ссылку на имя имп.ф-ции (или ее ординал), а VA точки входа в саму ф-цию ... т.е. ссылка на имя/ординал импортируемой ф-ции теряется (затирается вычисленным реальным значением ее точки входа)



Страницы: 1 вся ветка

Форум: "WinAPI";
Текущий архив: 2004.06.20;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.053 c
14-1086330044
Baks
2004-06-04 10:20
2004.06.20
Splash


3-1085646446
AlexXn
2004-05-27 12:27
2004.06.20
BDE


14-1086082718
Computerny_Geniy
2004-06-01 13:38
2004.06.20
Сообщение перед спящим режимом


6-1083306528
Tefal
2004-04-30 10:28
2004.06.20
Можно ли сделать снимок рабочего стола на удалённой машине.


1-1086294580
killer
2004-06-04 00:29
2004.06.20
Изменение цветов в StringGrid





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский