Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > ОС и железо
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 27.03.2017, 18:04
Doure Doure вне форума
Прохожий
 
Регистрация: 18.12.2016
Сообщения: 2
Версия Delphi: Delphi 7
Репутация: 10
Восклицание CreateRemoteThread - краш целового приложения

Доброго времени суток участники форума.
Возникла проблема, которую не знаю как исправить.

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

Рабочий вариант, только спустя успешного выполнения функции с моими параметрами, проходит 5-6 секунд и крашит.

Код:
type TShilutefn = function(id: Integer; r, g, b, alpha: real; k, d: boolean; s: real): integer; stdcall;
 
procedure ISetShilute(oShilute: TShilutefn); stdcall; //Функция что выполняется в памяти. 
begin
oShilute := Pointer($06D8ED0); //Указатель (имеет статистическое значение)
oShilute(30583, 1, 0, 0, 0.9, false, false, 999);
end;
 
function AllocAndCopyMem(hProcess: dword; ptBuffer: Pointer; iBuffSize: Int64): Pointer;
var
  Write: Cardinal;
begin
 WinHandle:= OpenProcess(PROCESS_ALL_ACCESS,False,hProcess);
 Write := 0;
 Result := VirtualAllocEx(hProcess, nil, iBuffSize, MEM_COMMIT Or MEM_RESERVE, PAGE_EXECUTE_READWRITE);
 WriteProcessMemory(hProcess, Result, ptBuffer, iBuffSize, Write);
end;
 
procedure SetShilute(hProcess: dword);
var
 tInj: TShilutefn;
 ptStruct:   Pointer;
 uTamFun:    UINT;
 ptEsp:      Pointer;
 hThread:    THandle;
begin
hProcess:= OpenProcess(PROCESS_ALL_ACCESS,False,hProcess);
 
ptStruct := AllocAndCopyMem(hProcess, @tInj, Sizeof(@tInj));
uTamFun := UINT(@SetShilute) - UINT(@ISetShilute);
 
ptEsp := AllocAndCopyMem(hProcess, @ISetShilute, uTamFun);
hThread := CreateRemoteThread(hProcess, nil, 0, ptEsp, ptStruct, 0, PDWORD(nil)^);
 
if hThread <> 0 then begin
CloseHandle(hThread);
//VirtualFreeEx(hProcess, ptStruct, 0, MEM_RELEASE);
//VirtualFreeEx(hProcess, ptEsp, 0, MEM_RELEASE);
end;
end;


Виде библиотеки работает идеально, но мне надо в приложении.
Надеюсь на вашу помощь! За ранее огромное спасибо!

Последний раз редактировалось Admin, 27.03.2017 в 19:27.
Ответить с цитированием
  #2  
Старый 27.03.2017, 18:28
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Вызывается функция, а результат в песок летит, может так надо
Код:
procedure ISetShilute(oShilute: TShilutefn); stdcall; //Функция что выполняется в памяти. 
var
i: integer;
begin
oShilute := Pointer($06D8ED0); //Указатель (имеет статистическое значение)
i:= oShilute(30583, 1, 0, 0, 0.9, false, false, 999);
end;
Ответить с цитированием
  #3  
Старый 27.03.2017, 18:51
Doure Doure вне форума
Прохожий
 
Регистрация: 18.12.2016
Сообщения: 2
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Да нет дело не в этом было, поставил вместо типа данных real, single.

Спасибо! Заработало всё!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 18:36.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter