从零构建自己的远控?用匿名管道执行powershell&cmd(9)
2021/9/3 7:06:31
本文主要是介绍从零构建自己的远控?用匿名管道执行powershell&cmd(9),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
#include <stdio.h> #include <windows.h> //读缓冲区 HANDLE m_hReadPipeHandle = NULL; //写缓冲区 HANDLE m_hWritePipeHandle = NULL; HANDLE m_hReadPipeShell = NULL; HANDLE m_hWritePipeShell = NULL; DWORD WINAPI ReadPipeThread(LPVOID lparam) { unsigned long BytesRead = 0; char ReadBuff[1024]; DWORD TotalBytesAvail; while (1) { Sleep(100); //检查管道是否有数据 while (PeekNamedPipe(m_hReadPipeHandle, ReadBuff, sizeof(ReadBuff), &BytesRead, &TotalBytesAvail, NULL)) { if (BytesRead <= 0) break; memset(ReadBuff, 0, sizeof(ReadBuff)); LPBYTE lpBuffer = (LPBYTE)LocalAlloc(LPTR, TotalBytesAvail); //读取管道数据 ReadFile(m_hReadPipeHandle, lpBuffer, TotalBytesAvail, &BytesRead, NULL); //把读到的数据发送当前窗口 puts((char *)lpBuffer); LocalFree(lpBuffer); //主控端的处理函数 } } return 0; } void main() { SECURITY_ATTRIBUTES sa = { 0 }; STARTUPINFO si = { 0 }; PROCESS_INFORMATION pi = { 0 }; char strShellPath[MAX_PATH] = { 0 }; sa.nLength = sizeof(sa); sa.lpSecurityDescriptor = NULL; sa.bInheritHandle = TRUE; //创建管道 if (!CreatePipe(&m_hReadPipeHandle, &m_hWritePipeShell, &sa, 0)) { if (m_hReadPipeHandle != NULL) CloseHandle(m_hReadPipeHandle); if (m_hWritePipeShell != NULL) CloseHandle(m_hWritePipeShell); return; } if (!CreatePipe(&m_hReadPipeShell, &m_hWritePipeHandle, &sa, 0)) { if (m_hWritePipeHandle != NULL) CloseHandle(m_hWritePipeHandle); if (m_hReadPipeShell != NULL) CloseHandle(m_hReadPipeShell); return; } memset((void*)&si, 0, sizeof(si)); memset((void*)&pi, 0, sizeof(pi)); GetStartupInfo(&si); si.cb = sizeof(STARTUPINFO); //标志wShowWindow,hStdInput,hStdOutput成员 si.dwFlags = STARTF_USESTDHANDLES | STARTF_USESHOWWINDOW; si.wShowWindow = SW_HIDE;//隐藏 si.hStdInput = m_hReadPipeShell;//写入 si.hStdOutput = si.hStdError = m_hWritePipeShell; //写出 GetSystemDirectory(strShellPath, MAX_PATH); //strcat(strShellPath, "\\cmd.exe");//cmd 命令执行 strcat(strShellPath, "\\WindowsPowerShell\\v1.0\\powershell.exe"); //创建cmd 进入 并指定管道 继承父进程 if (!CreateProcess(strShellPath, NULL, NULL, NULL, TRUE, NORMAL_PRIORITY_CLASS, NULL, NULL, &si, &pi)) { CloseHandle(m_hReadPipeHandle); CloseHandle(m_hWritePipeHandle); CloseHandle(m_hReadPipeShell); CloseHandle(m_hWritePipeShell); return; } HANDLE m_hProcessHandle = pi.hProcess; HANDLE m_hThreadHandle = pi.hThread; //接收消息 HANDLE m_hThreadRead = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)ReadPipeThread, NULL, 0, NULL); while (true) { DWORD TotalBytesAvail; char buffer[1024]; unsigned long ByteWrite; scanf_s("%s", buffer, 1024); int szlen = strlen(buffer); buffer[szlen] = '\n'; buffer[szlen + 1] = '\0'; WriteFile(m_hWritePipeHandle, (LPCVOID)buffer, strlen(buffer), &ByteWrite, NULL); } return ; }
这篇关于从零构建自己的远控?用匿名管道执行powershell&cmd(9)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用