IT창고/System
-
Dllinyection()IT창고/System 2007. 1. 22. 23:17
#include #include //Kernel32의 핸들을 구하는것..GetModuleHandle void DllInject(DWORD pid, char * path) { //process ID를 가지고 Process핸들을 얻는다. HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, 0, pid); //---------------------------------------------------------- //Kernel32.dll의 주소를 구한다. HMODULE hDll = GetModuleHandle("Kernel32.dll"); PTHREAD_START_ROUTINEf=(PTHREAD_START_ROUTINE) GetProcAddress(hDll, "LoadL..
-
다른 프로세스에 접근한여 메모리 값 가져오는 소스IT창고/System 2007. 1. 22. 23:16
#include #include #include void main() { DWORD pid = 4632;//목적 프로세스의 ID void * pAddr=(void *)0x0012FE80;//목적 주소. HANDLEhProcess=OpenProcess(PROCESS_ALL_ACCESS, 0 , pid); while(1) { getch(); printf("읽어온 주소 : %p\n",pAddr); //다른 프로세스(hProcess)의 메모리(pAddr)을 읽어 온다. char buf[256]={0}; DWORD len; ReadProcessMemory(hProcess, pAddr, buf, 256, &len); printf("읽어온 data : %s\n",buf); } }
-
스레드 풀링/이벤트(스레드 감시)IT창고/System 2007. 1. 22. 23:16
/*#include #include DWORD WINAPI foo(void *p) { DWORD pid=(DWORD)p; HANDLEhProcess=OpenProcess(PROCESS_ALL_ACCESS, 0 ,pid); if(hProcess == 0) { printf("Can't Get Process Handle...\n"); return 0; } HANDLEhEvent =OpenEvent(EVENT_ALL_ACCESS,0,"EXIT_EVENT"); HANDLEh[2]={hProcess,hEvent}; DWORD ret =WaitForMultipleObjects(2,h,FALSE,//둘중에 하나만 시그널 되면 INFINITE); if(ret == WAIT_OBJECT_0) { printf("\n___%..
-
세마포어/뮤텍스/이벤트IT창고/System 2007. 1. 22. 23:15
// 세마포어/*#include #include void main() { HANDLE hSemaphore=CreateSemaphore(0,//보안 3,//Count초기값 3,//최대카운트 "s");//이름 printf("세마포어를 대기합니다.\n"); WaitForSingleObject(hSemaphore,INFINITE);//++Count printf("세마포어를 획득\n"); MessageBox(0,"Release??","",MB_OK); LONG old; ReleaseSemaphore(hSemaphore,1,&old); CloseHandle(hSemaphore); //리소스 카운팅 //세마포어는 카운트 초기값과 최대카운트가있다. //세마포어는 if(카운트)시그널 이다. //카운트는 WaitForSi..