Page Menu
Home
desp's stash
Search
Configure Global Search
Log In
Files
F527263
DllInjection.cpp
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
5 KB
Subscribers
None
DllInjection.cpp
View Options
#include
"DllInjection.h"
#include
"Logger.h"
#include
<Psapi.h>
#include
"NativeWinApi.h"
//#define DEBUG_COMMENTS
HMODULE
DllInjection
::
dllInjection
(
HANDLE
hProcess
,
const
WCHAR
*
filename
)
{
LPVOID
remoteMemory
=
0
;
SIZE_T
memorySize
=
0
;
HANDLE
hThread
=
0
;
HMODULE
hModule
=
0
;
memorySize
=
(
wcslen
(
filename
)
+
1
)
*
sizeof
(
WCHAR
);
if
(
memorySize
<
7
)
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"dllInjection :: memorySize invalid
\r\n
"
);
#endif
return
0
;
}
remoteMemory
=
VirtualAllocEx
(
hProcess
,
NULL
,
memorySize
,
MEM_RESERVE
|
MEM_COMMIT
,
PAGE_READWRITE
);
if
(
remoteMemory
==
0
)
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"dllInjection :: VirtualAllocEx failed 0x%X
\r\n
"
,
GetLastError
());
#endif
return
0
;
}
if
(
WriteProcessMemory
(
hProcess
,
remoteMemory
,
filename
,
memorySize
,
&
memorySize
))
{
hThread
=
startRemoteThread
(
hProcess
,
LoadLibraryW
,
remoteMemory
);
if
(
hThread
)
{
WaitForSingleObject
(
hThread
,
INFINITE
);
#ifdef _WIN64
hModule
=
getModuleHandleByFilename
(
hProcess
,
filename
);
#else
//returns only 32 bit values -> design bug by microsoft
if
(
!
GetExitCodeThread
(
hThread
,
(
LPDWORD
)
&
hModule
))
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"dllInjection :: GetExitCodeThread failed 0x%X
\r\n
"
,
GetLastError
());
#endif
hModule
=
0
;
}
#endif
CloseHandle
(
hThread
);
}
else
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"dllInjection :: CreateRemoteThread failed 0x%X
\r\n
"
,
GetLastError
());
#endif
}
}
else
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"dllInjection :: WriteProcessMemory failed 0x%X
\r\n
"
,
GetLastError
());
#endif
}
VirtualFreeEx
(
hProcess
,
remoteMemory
,
0
,
MEM_RELEASE
);
return
hModule
;
}
bool
DllInjection
::
unloadDllInProcess
(
HANDLE
hProcess
,
HMODULE
hModule
)
{
HANDLE
hThread
=
0
;
DWORD
lpThreadId
=
0
;
BOOL
freeLibraryRet
=
0
;
hThread
=
startRemoteThread
(
hProcess
,
FreeLibrary
,
hModule
);
if
(
hThread
)
{
WaitForSingleObject
(
hThread
,
INFINITE
);
if
(
!
GetExitCodeThread
(
hThread
,
(
LPDWORD
)
&
freeLibraryRet
))
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"unloadDllInProcess :: GetExitCodeThread failed 0x%X
\r\n
"
,
GetLastError
());
#endif
freeLibraryRet
=
0
;
}
CloseHandle
(
hThread
);
}
else
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"unloadDllInProcess :: CreateRemoteThread failed 0x%X
\r\n
"
,
GetLastError
());
#endif
}
return
freeLibraryRet
!=
0
;
}
HMODULE
DllInjection
::
getModuleHandleByFilename
(
HANDLE
hProcess
,
const
WCHAR
*
filename
)
{
HMODULE
*
hMods
=
0
;
HMODULE
hModResult
=
0
;
DWORD
count
=
0
;
WCHAR
target
[
MAX_PATH
];
DWORD
cbNeeded
=
0
;
bool
notEnough
=
true
;
count
=
100
;
hMods
=
new
HMODULE
[
count
];
do
{
if
(
!
EnumProcessModules
(
hProcess
,
hMods
,
count
*
sizeof
(
HMODULE
),
&
cbNeeded
))
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"DllInjection::getModuleHandle :: EnumProcessModules failed count %d
\r\n
"
,
count
);
#endif
delete
[]
hMods
;
return
0
;
}
if
(
(
count
*
sizeof
(
HMODULE
))
<
cbNeeded
)
{
delete
[]
hMods
;
count
+=
100
;
hMods
=
new
HMODULE
[
count
];
}
else
{
notEnough
=
false
;
}
}
while
(
notEnough
);
for
(
DWORD
i
=
0
;
i
<
(
cbNeeded
/
sizeof
(
HMODULE
));
i
++
)
{
if
(
GetModuleFileNameExW
(
hProcess
,
hMods
[
i
],
target
,
_countof
(
target
)))
{
if
(
!
_wcsicmp
(
target
,
filename
))
{
hModResult
=
hMods
[
i
];
break
;
}
}
else
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"DllInjection::getModuleHandle :: GetModuleFileNameExW failed 0x%X
\r\n
"
,
GetLastError
());
#endif
}
}
if
(
!
hModResult
)
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"DllInjection::getModuleHandle :: Handle not found
\r\n
"
);
#endif
}
delete
[]
hMods
;
return
hModResult
;
}
void
DllInjection
::
specialThreadSettings
(
HANDLE
hThread
)
{
if
(
hThread
)
{
if
(
!
SetThreadPriority
(
hThread
,
THREAD_PRIORITY_TIME_CRITICAL
))
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"specialThreadSettings :: SetThreadPriority(hThread, THREAD_PRIORITY_TIME_CRITICAL) failed 0x%X
\r\n
"
,
GetLastError
());
#endif
}
if
(
NativeWinApi
::
NtSetInformationThread
)
{
if
(
NativeWinApi
::
NtSetInformationThread
(
hThread
,
ThreadHideFromDebugger
,
0
,
0
)
!=
STATUS_SUCCESS
)
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"specialThreadSettings :: NtSetInformationThread ThreadHideFromDebugger failed
\r\n
"
);
#endif
}
}
}
}
HANDLE
DllInjection
::
startRemoteThread
(
HANDLE
hProcess
,
LPVOID
lpStartAddress
,
LPVOID
lpParameter
)
{
HANDLE
hThread
=
0
;
hThread
=
customCreateRemoteThread
(
hProcess
,
lpStartAddress
,
lpParameter
);
if
(
hThread
)
{
specialThreadSettings
(
hThread
);
ResumeThread
(
hThread
);
}
return
hThread
;
}
HANDLE
DllInjection
::
customCreateRemoteThread
(
HANDLE
hProcess
,
LPVOID
lpStartAddress
,
LPVOID
lpParameter
)
{
DWORD
lpThreadId
=
0
;
HANDLE
hThread
=
0
;
NTSTATUS
ntStatus
=
0
;
if
(
NativeWinApi
::
NtCreateThreadEx
)
{
#define THREAD_ALL_ACCESS_VISTA_7 (STANDARD_RIGHTS_REQUIRED | SYNCHRONIZE | 0xFFFF)
//for windows vista/7
ntStatus
=
NativeWinApi
::
NtCreateThreadEx
(
&
hThread
,
THREAD_ALL_ACCESS_VISTA_7
,
0
,
hProcess
,
(
LPTHREAD_START_ROUTINE
)
lpStartAddress
,
(
LPVOID
)
lpParameter
,
TRUE
,
0
,
0
,
0
,
0
);
if
(
NT_SUCCESS
(
ntStatus
))
{
return
hThread
;
}
else
{
#ifdef DEBUG_COMMENTS
Logger
::
debugLog
(
L
"customCreateRemoteThread :: NtCreateThreadEx failed 0x%X
\r\n
"
,
NativeWinApi
::
RtlNtStatusToDosError
(
ntStatus
));
#endif
return
0
;
}
}
else
{
return
CreateRemoteThread
(
hProcess
,
NULL
,
NULL
,(
LPTHREAD_START_ROUTINE
)
lpStartAddress
,
lpParameter
,
CREATE_SUSPENDED
,
&
lpThreadId
);
}
}
File Metadata
Details
Attached
Mime Type
text/x-c
Expires
Wed, Jan 7, 1:49 PM (8 h, 3 m)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
1b/c3/f05595803d5191ccdb02be8f37d9
Attached To
rSCY Scylla
Event Timeline
Log In to Comment