не всегда сработает, к примеру бандикам поллит адрес своего хука и если ставишь свой он ставит свой поверх и хуячит твой.Почему бы не поставить хук на хук
Я имел ввиду поставить хук на чужой детурне всегда сработает, к примеру бандикам поллит адрес своего хука и если ставишь свой он ставит свой поверх и хуячит твой.
можно поставить хук после пролога - на 5 байт дальше начала функции условно. по крайней мере, так я пофиксил работу с бандикамом в ультравх.
#include "loaderFree.hpp"
void downloadFile(const char *dllLink, const char *dllPath)
{
URLDownloadToFileA(0, dllLink, dllPath, 0, 0);
DeleteUrlCacheEntryA(dllLink);
std::cout << "[INFO]: software downloaded!" << std::endl;
}
bool injectDll(const char *dllPath) // by ICoded
{
HWND hWnd = FindWindowA("NULL", "GTA:SA:MP");
if (!hWnd) {
std::cout << "[ERROR]: please, start game" << std::endl;
return false;
}
DWORD pid;
DWORD tid = GetWindowThreadProcessId(hWnd, &pid);
if (!tid)
{
std::cout << "[ERROR]: cannot get process id" << std::endl;
return false;
}
HANDLE hThread = OpenThread(THREAD_ALL_ACCESS, FALSE, tid);
if (!hThread || hThread == INVALID_HANDLE_VALUE)
{
std::cout << "[ERROR]: cannot open process" << std::endl;
return false;
}
HMODULE hMod = LoadLibraryExA(dllPath, NULL, DONT_RESOLVE_DLL_REFERENCES);
if (!hMod)
{
std::cout << "[ERROR]: cannot load software" << std::endl;
return false;
}
if (!SetWindowsHookExW(3, (HOOKPROC)GetProcAddress, hMod, tid))
{
std::cout << "[ERROR]: cannot set hook" << std::endl;
return false;
}
std::cout << "[INFO]: injected!" << std::endl;
Sleep(5000);
if (PostThreadMessageW(tid, 0, 0, 0))
{
ShowWindow(GetConsoleWindow(), SW_HIDE);
WaitForSingleObject(hThread, INFINITE);
CloseHandle(hThread);
}
return true;
}
int main()
{
std::cout << "[INFO]: starting download..." << std::endl;
downloadFile(DLL_LINK, DLL_PATH);
std::cout << "[INFO]: injecting..." << std::endl;
injectDll(DLL_PATH);
system("pause");
return true;
}
Попробуй такПриветствую, решил подогнать лоадер с метод инъекции SetWindowsHookEx, изменял только FindWindowA, но лоадер стопается на моменте [ERROR]: please, start game, что не так?
C++:#include "loaderFree.hpp" void downloadFile(const char *dllLink, const char *dllPath) { URLDownloadToFileA(0, dllLink, dllPath, 0, 0); DeleteUrlCacheEntryA(dllLink); std::cout << "[INFO]: software downloaded!" << std::endl; } bool injectDll(const char *dllPath) // by ICoded { HWND hWnd = FindWindowA("NULL", "GTA:SA:MP"); if (!hWnd) { std::cout << "[ERROR]: please, start game" << std::endl; return false; } DWORD pid; DWORD tid = GetWindowThreadProcessId(hWnd, &pid); if (!tid) { std::cout << "[ERROR]: cannot get process id" << std::endl; return false; } HANDLE hThread = OpenThread(THREAD_ALL_ACCESS, FALSE, tid); if (!hThread || hThread == INVALID_HANDLE_VALUE) { std::cout << "[ERROR]: cannot open process" << std::endl; return false; } HMODULE hMod = LoadLibraryExA(dllPath, NULL, DONT_RESOLVE_DLL_REFERENCES); if (!hMod) { std::cout << "[ERROR]: cannot load software" << std::endl; return false; } if (!SetWindowsHookExW(3, (HOOKPROC)GetProcAddress, hMod, tid)) { std::cout << "[ERROR]: cannot set hook" << std::endl; return false; } std::cout << "[INFO]: injected!" << std::endl; Sleep(5000); if (PostThreadMessageW(tid, 0, 0, 0)) { ShowWindow(GetConsoleWindow(), SW_HIDE); WaitForSingleObject(hThread, INFINITE); CloseHandle(hThread); } return true; } int main() { std::cout << "[INFO]: starting download..." << std::endl; downloadFile(DLL_LINK, DLL_PATH); std::cout << "[INFO]: injecting..." << std::endl; injectDll(DLL_PATH); system("pause"); return true; }
Теперь ошибка с LoadLibrary, cannot load softwareПопробуй так
HWND hWnd = FindWindowA(NULL, "GTA:SA:MP");
+ старт программы от имени админа
Возращай код ошибки через GetLastError и уже её гуглиТеперь ошибка с LoadLibrary, cannot load software
Поток 17688 завершился с кодом 1 (0x1).Возращай код ошибки через GetLastError и уже её гугли
обрати внимание, что твой ехешник должен быть х32, соответствуя игреПоток 17688 завершился с кодом 1 (0x1).
ERROR_INVALID_FUNCTION
1 (0x1)
Incorrect function.
Перебрал все ошибки мира, а вот оно какое оказалось решение..обрати внимание, что твой ехешник должен быть х32, соответствуя игре
А вот ещё один вопрос, использую usermode mmap IAT, игру просто всегда крашит, пробывал так же древнейший mmap thread hijacking - результат один и тоже, это так же из-за x32 архитектуры этой прекрасной игры?обрати внимание, что твой ехешник должен быть х32, соответствуя игре
А можно русским языком.Пасаны как сделать инжект закриптованного кода в память с последующим декриптом так-же в памяти. XDD
Кто шарит хелпаните молодому
upd сверхуА можно русским языком.
Декриптом это ты о чём?
как получить данные из входящего от сервера RPC (кастомный рпс)