Note
来源:互联网 发布:fc2最新域名网站 编辑:程序博客网 时间:2024/04/30 08:57
#include <iostream>
#include <windows.h>
using namespace::std;
int Inject(HWND hwnd, char *name);
int main()
{
char dll[]="c:/tt.dll";//change the name to your dll
HWND hw=0;
hw = FindWindow("Notepad",NULL);//change the "Notepad" to your window name
if(!hw)
{
cout<<"Unable find window"<<endl;
return 0;
}
if(Inject(hw,dll))
{
cout<<"DLL has injected into the process successfully"<<endl;
}
else
{
cout<<"Couldn't inject DLL into process"<<endl;
}
return 0;
}
int Inject(HWND hwnd,char *name)
{
DWORD Pid;
HANDLE hProcess,hThread;
DWORD BytesWritten;
LPVOID mem;
GetWindowThreadProcessId(hwnd, &Pid);
hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, Pid);
if(!hProcess)
return 0;
mem = VirtualAllocEx(hProcess, NULL, strlen(name), MEM_RESERVE|MEM_COMMIT, PAGE_READWRITE);
if(mem==NULL)
{
CloseHandle(hProcess);
return 0;
}
if(WriteProcessMemory(hProcess, mem, (LPVOID)name, strlen(name), &BytesWritten))
{
hThread = CreateRemoteThread(hProcess, NULL, 0, (LPTHREAD_START_ROUTINE)GetProcAddress(GetModuleHandle("KERNEL32.DLL"), "LoadLibraryA"), mem, 0, NULL);
if(!hThread)
{
VirtualFreeEx(hProcess,NULL,strlen(name),MEM_RESERVE|MEM_COMMIT);
CloseHandle(hProcess);
return 0;
}
VirtualFreeEx(hProcess,NULL,strlen(name),MEM_RESERVE|MEM_COMMIT);
CloseHandle(hThread);
CloseHandle(hProcess);
return 1;
}
VirtualFreeEx(hProcess,NULL,strlen(name),MEM_RESERVE|MEM_COMMIT);
CloseHandle(hProcess);
return 0;
}
- note
- note
- NOTE
- note
- Note
- note
- note
- Note
- note
- Note
- Note
- note
- Note
- Note
- Note
- note
- note
- note
- 如何在仅仅启动HDFS情况下处理HDFS中的文件
- javascript AJAX 中文
- ejb常见面试题
- DllMain函数不特殊
- INTERNAL ERROR 2739错误
- Note
- 美国Android占28%份额 摩托Droid最受欢迎
- Myeclipse8.0下配置Spket
- rhce之路--linux的基本命令
- 在eclipse中生成英文的javadoc(转自:http://zyp731.javaeye.com/blog/98432)
- 关于重启系统服务
- 数据库方面常见面试题
- 关于FormView在编辑模板下找不到控件的问题
- 求助 SUM 和ROUP BY 的使用方法。感激不尽~!!![