远程注入代码,远程调用Call

 1、远程注入代码,调用打坐CALL

   

 HANDLE CreateRemoteThread(

 HANDLE hProcess,        //在指定的进程句柄里创建线程

 LPSECURITY_ATTRIBUTES lpThreadAttributes,  //安全结构指针 nil

 DWORD dwStackSize,      // 初始创建线程堆栈大小0

 LPTHREAD_START_ROUTINE lpStartAddress,//CALL地址

 LPVOID lpParameter,     // 给远程CALL 传递的参数 nil

 DWORD dwCreationFlags,  // 创建标志 0

 LPDWORD lpThreadId      // 返回创建线程ID@tid

);

LPVOID VirtualAllocEx(

 HANDLE hProcess,  //进程句柄 

 LPVOID lpAddress, // 指定分配空间的起始地址

 DWORD dwSize,     // 分配空间大小

 DWORD flAllocationType,

                    // 分配空间类型

 DWORD flProtect   // 空间页面访问权限

);

 

  用spy++获取标题:'Element Client

 

 

2、远程调用CALL

CreateRemoteThread

 ThreadHandle:=  CreateRemoteThread(hProcess,nil, 0,打坐CALL地址, nil, 0, 返回远程创建线程ID);

//FindWindow 获取窗口

//GetWindowThreadProcessId //获取窗口的线程TID

//OpenProcess              //打开进程 获取进程句柄

//VirtualAllocEx(hProcess,nil,Size,MEM_COMMIT orMEM_RESERVE,PAGE_EXECUTE_READWRITE);

//WriteProcessMemory

//CreateRemoteThread

//WaitForSingleObject

//GetExitCodeThread

//VirtualFreeEx

asm

  push 1

  mov ecx,$95E800

  add ecx,$1C

  mov ecx,[ecx] //ecx=Pointer(ecx^)

  add ecx,$24    // ecx=ecx+$24

  mov ecx,[ecx]

  add ecx,$918

  mov ecx,[ecx]

  add ecx,$14

  mov ecx,[ecx]

  add ecx,$1C

  mov ecx,[ecx]

  mov ebx,$452b20

  call ebx

  end;

 

var

  h:HWND;

 tid,hProcess:Thandle;

  Calladdr:Pointer;

  writeByte:DWORD;

begin

   h:=findwindow(nil,'Element Client');

   windows.GetWindowThreadProcessId(h,tid);

   hProcess:=windows.OpenProcess(windows.PROCESS_ALL_ACCESS,false,tid);

    //在游戏进程里分配内存空间

    Calladdr:=VirtualAllocEx(hProcess,nil,windows.MAX_PATH,windows.MEM_COMMITOR windows.MEM_RESERVE,windows.PAGE_EXECUTE_READWRITE);

    //在游戏内存空间里写入代码

   WriteProcessMemory(hProcess,Calladdr,@sitCall,MAX_PATH,writeByte);

    //调用远程代码

   CreateRemoteThread(hProcess,nil,0,Calladdr,nil,0,writeByte);

    VirtualFreeEx(hProcess,nil,windows.MAX_PATH,windows.MEM_COMMITOR windows.MEM_RESERVE);

end;



//官方网站:www.feiyuol.com //郁金香灬老师 //QQ 150330575 //个人网站:www.yjxsoft.com 跨进程调用CALL 跨进程调用带多个的参数CALL // myInject_dll.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include #include"RWA.h" //PVOID 跨进程分配内存(WORD nSize ); //1、获取进程句柄 //2、读写 分配内存 创建线程 //3、跨进程分配内存 void mycall() { PVOID p1=跨进程分配内存(1000); printf("分配的内存地址=%p\n",p1); printf("按回车键 释放内存\n"); getchar(); 跨进程释放内存(p1,1000); printf("已经 释放内存\n"); } LPTHREAD_START_ROUTINE a; BOOL 跨进程调用CALL(PVOID pcall地址,PVOID plst参数 ); //LoadLibraryA(dll名字指针) //MessageBeep(1) void Test远程调用MessageBeep() { 跨进程调用CALL(MessageBeep,(PVOID)0x12768); } //注入my022MFC.dll到目标进程 void Test3() { char szDllName[]="my022MFC.dll"; //全路径 // char szDllName[]="C:\\Users\\yjxsoft\\Documents\\visual studio 2010\\Projects\\my022\\Debug\\my022MFC.dll"; PVOID p1=跨进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*跨进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 跨进程调用CALL(LoadLibraryA,(PVOID)p1); } void Test4() { // char szDllName[]="my022MFC.dll"; //全路径 char szDllName[]="E:\\1905\\代码\\my022-24\\Debug\\my022MFC.dll"; PVOID p1=跨进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*跨进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 跨进程调用CALL(LoadLibraryA,(PVOID)p1); } int _tmain(int argc, _TCHAR* argv[]) { //mycall(); Test3(); Test4(); return 0; } //作业 //1、练习跨进程注入DLL //2、跨进程分配的内存内存 使用完后 用VirtualFreeEx释放掉 //3、进程句柄使用完后用CloseHandle释放句柄资源
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小蚂蚁_CrkRes

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值