进程伪装实现将进程伪装成任意程序

本文探讨了如何通过修改进程环境块(PEB)中的进程路径和命令行信息,实现进程伪装,详细介绍了获取进程句柄、访问PEB以及篡改关键字段以达到欺骗系统的目的。
摘要由CSDN通过智能技术生成

进程伪装


修改指定进程环境块中的进程路径以及命令行信息,从而达到进程 伪装的效果。

  • 获取进程的句柄
  • 内联汇编获取peb
  • 修改命令行和imagepath
#include<windows.h>
#include<winternl.h>

BOOL DisguiseProcess(wchar_t *lpwszPath, wchar_t *lpwszCmd);

int main()
{
	wchar_t *lpwszPath = L"c:\\windows\\system32\\calc.exe";
	wchar_t *lpwszCmd = L"yeanhoo's calc";
	DisguiseProcess(lpwszPath, lpwszCmd);
	system("pause");
}

BOOL DisguiseProcess(wchar_t *lpwszPath, wchar_t *lpwszCmd)
{
	// 打开进程获取句柄
	HANDLE hProcess = GetModuleHandle(NULL);

	PPEB peb = { 0 };
	USHORT usCmdLen = 0;
	USHORT usPathLen = 0;
	
	__asm
	{
		mov	eax,fs:[30h]
		mov peb,eax
	}
	// 获取指定进程环境块结构中的ProcessParameters, 指针指向的是指定进程空间中


	usCmdLen = 2 + 2 * wcslen(lpwszCmd);
	(*peb).ProcessParameters->CommandLine.Buffer = lpwszCmd;
	(*peb).ProcessParameters->CommandLine.Length = usCmdLen
  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在 C 语言中,可以使用 signal 函数来指定信号处理函数,从而实现信号回收子进程。具体步骤如下: 1. 在主函数中,使用 fork 函数创建子进程。 2. 在子进程中,执行需要的任务。 3. 在主进程中,使用 signal 函数指定 SIGCHLD 信号的处理函数。SIGCHLD 信号是在子进程终止或停止时发送给父进程的信号。 4. 在信号处理函数中,使用 waitpid 函数回收子进程。waitpid 函数可以阻塞父进程,直到指定的子进程结束。 下面是一个示例程序: ```c #include <stdio.h> #include <stdlib.h> #include <signal.h> #include <unistd.h> #include <sys/wait.h> void sig_handler(int signo) { if (signo == SIGCHLD) { int status; pid_t pid = waitpid(-1, &status, WNOHANG); if (pid > 0) { printf("Child process %d exited with status %d.\n", pid, status); } } } int main() { pid_t pid = fork(); if (pid == 0) { // 子进程执行任务 printf("Child process %d is running.\n", getpid()); sleep(5); printf("Child process %d finished.\n", getpid()); exit(0); } else if (pid > 0) { // 父进程等待子进程结束 signal(SIGCHLD, sig_handler); while (1) { sleep(1); } } else { fprintf(stderr, "Failed to fork.\n"); exit(1); } return 0; } ``` 在上面的程序中,首先使用 fork 函数创建子进程。在子进程中,模拟执行一个需要 5 秒钟的任务,然后退出。在父进程中,使用 signal 函数指定 SIGCHLD 信号的处理函数为 sig_handler。在 sig_handler 函数中,使用 waitpid 函数回收子进程。最后,父进程进入一个死循环,防止程序退出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值