小心,小心,再小心,远程进程还是崩溃了!!!????

yesor 2009-06-02 07:54:24
远程注入的问题,不用DLL,直接往远程进程写代码,用创建远程线程的方法启动代码,为何崩溃???
#include<windows.h>
#include<stdio.h>
char *szText;
/*程序Release下编译*/
void ThreadFunc(FARPROC AddrMessageBoxA)
{
((int (WINAPI*)(HWND,LPCSTR,LPCSTR,UINT))AddrMessageBoxA)(NULL,NULL,NULL,MB_OK);/*第二个参数,如果传递szText,远程进程就会崩溃,数据已经写入远程进程,怎么会呢????*/
}
void AfterThreadFunc()
{
}
void main()
{
char *szBuffer="good luck";
SIZE_T sizeData=sizeof(szBuffer);
SIZE_T sizeCode=(SIZE_T)AfterThreadFunc-(SIZE_T)ThreadFunc;
HWND hwnd=FindWindow(NULL,"扫雷");/*随便找一个窗口*/
if(hwnd==NULL)
{
puts("Cannot find window");
return;
}
DWORD dwProcess;
GetWindowThreadProcessId(hwnd,&dwProcess);
HANDLE hProcess=OpenProcess(PROCESS_ALL_ACCESS,FALSE,dwProcess);
if(hProcess==NULL)
{
puts("OpenProcess failed");
return;
}
LPVOID pAddrData;
LPVOID pAddrCode;
//////////////////////写数据//////////////////////////////////////////////////////////
pAddrData=VirtualAllocEx(hProcess,NULL,sizeData,MEM_COMMIT,PAGE_READWRITE);
if(pAddrData==NULL)
{
puts("VirtualAllocEx failed");
return;
}
if(WriteProcessMemory(hProcess,pAddrData,szBuffer,sizeData,NULL)==0)
{
puts("WriteProcessMemory failed");
return;
}
szText=(char*)pAddrData;//就是这里,已经把指针指向远程的字符串地址了啊?
///////////////写代码/////////////////////////////////////////////////////////////////
pAddrCode=VirtualAllocEx(hProcess,NULL,sizeCode,MEM_COMMIT,PAGE_EXECUTE_READWRITE);
if(pAddrCode==NULL)
{
puts("VirtualAllocEx failed");
return;
}
if(WriteProcessMemory(hProcess,pAddrCode,ThreadFunc,sizeCode,NULL)==0)
{
puts("WriteProcessMemory failed");
return;
}
///////////////////////远程线程启动代码//////////////////////////////////////////////////////
HMODULE hUser32=GetModuleHandle("USER32.dll");
if(hUser32==NULL)
{
puts("GetModuleHandle failed");
return;
}
FARPROC AddrMessageBoxA=GetProcAddress(hUser32,"MessageBoxA");
HANDLE hThread=CreateRemoteThread(hProcess,NULL,NULL,LPTHREAD_START_ROUTINE(pAddrCode),AddrMessageBoxA,0,NULL);
//////////////////////////////////////////////////////////////////////////////////////////////
WaitForSingleObject(hThread,INFINITE);
VirtualFreeEx(hProcess,pAddrData,sizeData,MEM_DECOMMIT);
VirtualFreeEx(hProcess,pAddrCode,sizeCode,MEM_DECOMMIT);
CloseHandle(hThread);
CloseHandle(hProcess);
CloseHandle(hwnd);

}
...全文
91 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
yekoufeng 2009-06-03
  • 打赏
  • 举报
回复
期待答案
yesor 2009-06-03
  • 打赏
  • 举报
回复
看来必须在CreateRemote传参数啊!!结贴>
yesor 2009-06-03
  • 打赏
  • 举报
回复
怎么办啊,到底怎么改才好呢?
  • 打赏
  • 举报
回复
那个注入不错
MARK
帮顶
GaA_Ra 2009-06-02
  • 打赏
  • 举报
回复
注入的程序代码ThreadFunc如下
00401000 . A1 60994000 MOV EAX,DWORD PTR DS:[409960]
00401005 . 6A 00 PUSH 0
00401007 . 6A 00 PUSH 0
00401009 . 50 PUSH EAX
0040100A . 6A 00 PUSH 0
0040100C . FF5424 14 CALL DWORD PTR SS:[ESP+14]
00401010 . C3 RETN
全局变量保存在DS:[409960]这个地址里
当你写入目标进程时,代码不变
CreateRemoteThread的时候,在目标进程中也按上面的流程执行
那么,他会取目标程序的DS:[409960]作为自己的szText值,而不是注入程序的DS:[409960]作为参数
因此就有违规访问的错误

当把szText改为NULL时,注入的程序代码ThreadFunc如下
00401000 . 6A 00 PUSH 0
00401002 . 6A 00 PUSH 0
00401004 . 6A 00 PUSH 0
00401006 . 6A 00 PUSH 0
00401008 . FF5424 14 CALL DWORD PTR SS:[ESP+14]
0040100C . C3 RETN
不涉及地址相关的操作,因此能够正常.
不知道我这样说对不对~
yesor 2009-06-02
  • 打赏
  • 举报
回复
依然不行!!!!!!!!!!!
stjay 2009-06-02
  • 打赏
  • 举报
回复
修正
SIZE_T sizeData=strlen(szBuffer)+1;
stjay 2009-06-02
  • 打赏
  • 举报
回复
SIZE_T sizeData=strlen(szBuffer);
小心试试

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧