news 2026/5/1 5:58:17

驱动隐藏进程 (本人手写)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
驱动隐藏进程 (本人手写)
#include <ntifs.h> #include <ntddk.h> #include <wdm.h> // 使用动态获取偏移的方法,而不是硬编码 typedef struct _PROCESS_INFO { ULONG UniqueProcessIdOffset; } PROCESS_INFO; // 全局变量 PROCESS_INFO g_ProcessInfo = { 0 }; // 函数声明 VOID DriverUnload(PDRIVER_OBJECT DriverObject); NTSTATUS GetProcessIdOffset(PULONG pOffset); NTSTATUS HideProcessById(HANDLE ProcessId); #pragma comment(lib, "ntoskrnl.lib") // 驱动入口点 NTSTATUS DriverEntry(PDRIVER_OBJECT DriverObject, PUNICODE_STRING RegistryPath) { UNREFERENCED_PARAMETER(RegistryPath); NTSTATUS status = STATUS_SUCCESS; DbgPrint("[DriverEntry] Driver loaded\n"); // 设置卸载函数 DriverObject->DriverUnload = DriverUnload; // 获取UniqueProcessId的偏移量 status = GetProcessIdOffset(&g_ProcessInfo.UniqueProcessIdOffset); if (!NT_SUCCESS(status)) { DbgPrint("[DriverEntry] Failed to get process ID offset: 0x%X\n", status); return status; } DbgPrint("[DriverEntry] UniqueProcessId offset: 0x%X\n", g_ProcessInfo.UniqueProcessIdOffset); // 隐藏目标进程(示例:隐藏进程ID 1234) HANDLE targetProcessId = (HANDLE)4616; status = HideProcessById(targetProcessId); if (NT_SUCCESS(status)) { DbgPrint("[DriverEntry] Successfully modified process with ID %lu\n", (ULONG)targetProcessId); } else { DbgPrint("[DriverEntry] Failed to modify process with ID %lu (Status: 0x%X)\n", (ULONG)targetProcessId, status); } return STATUS_SUCCESS; } // 获取EPROCESS中UniqueProcessId的偏移量 NTSTATUS GetProcessIdOffset(PULONG pOffset) { PEPROCESS pSystemProcess = NULL; HANDLE pid = (HANDLE)4; // System进程的PID通常为4 NTSTATUS status = PsLookupProcessByProcessId(pid, &pSystemProcess); if (!NT_SUCCESS(status)) { DbgPrint("[GetProcessIdOffset] Failed to lookup System process: 0x%X\n", status); return status; } // 获取EPROCESS结构体中的UniqueProcessId字段 // 这里使用更安全的方法,但需要包含Ps.h中的声明 // 在实际驱动中,可能需要使用模式扫描或特征码定位 // 临时使用已知偏移(应该通过模式扫描动态获取) // Windows版本不同,偏移量也不同,这里只是示例 #ifdef _WIN64 * pOffset = 0x1d0; // 64位系统的常见偏移 #else * pOffset = 0x180; // 32位系统的常见偏移 #endif ObDereferenceObject(pSystemProcess); return STATUS_SUCCESS; } // 隐藏指定PID的进程 NTSTATUS HideProcessById(HANDLE ProcessId) { PEPROCESS pEprocess = NULL; NTSTATUS status = STATUS_SUCCESS; // 查找目标进程 status = PsLookupProcessByProcessId(ProcessId, &pEprocess); if (!NT_SUCCESS(status)) { DbgPrint("[HideProcessById] Failed to find process with ID %lu: 0x%X\n", (ULONG)ProcessId, status); return status; } // 安全地修改UniqueProcessId // 使用正确的指针算术和类型转换 ULONG_PTR processAddress = (ULONG_PTR)pEprocess; // 获取UniqueProcessId指针 PHANDLE pUniqueProcessId = (PHANDLE)(processAddress + g_ProcessInfo.UniqueProcessIdOffset); DbgPrint("[HideProcessById] Process EPROCESS: 0x%p, UniqueProcessId: 0x%p -> %lu\n", pEprocess, pUniqueProcessId, (ULONG)*pUniqueProcessId); // 将UniqueProcessId设为0(隐藏进程) // 注意:这只是一个简单的示例,实际隐藏进程需要更多步骤 *pUniqueProcessId = (HANDLE)0; DbgPrint("[HideProcessById] Modified UniqueProcessId to 0\n"); // 释放EPROCESS引用 ObDereferenceObject(pEprocess); return STATUS_SUCCESS; } // 驱动卸载函数 VOID DriverUnload(PDRIVER_OBJECT DriverObject) { UNREFERENCED_PARAMETER(DriverObject); DbgPrint("[DriverUnload] Driver unloading\n"); // 这里可以添加恢复被隐藏进程的代码 // 在实际驱动中,需要维护被隐藏进程的列表以便恢复 DbgPrint("[DriverUnload] Driver unloaded successfully\n"); }

对于 目标pid 和 偏移值 需要输入,目标pid就不用说了,

偏移值UniqueProcessIdOffset在调试内核时使用: dt _EPROCESS 命令查看

https://gitee.com/geek-mm/system-permission-loader

这是本人做的东西,代码和程序全部上传。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 0:23:15

紧急预警:现有车载语音系统或将被淘汰,Open-AutoGLM时代已来临

第一章&#xff1a;Open-AutoGLM时代下的车载交互范式变革随着大语言模型技术的深度演进&#xff0c;Open-AutoGLM 正在重塑智能汽车的人机交互边界。该模型专为车载场景优化&#xff0c;在低延迟推理、多模态感知与上下文持续理解方面实现突破&#xff0c;使车辆从被动响应设备…

作者头像 李华
网站建设 2026/4/23 9:42:14

Open-AutoGLM调度引擎深度解析:如何实现毫秒级城市资源响应?

第一章&#xff1a;Open-AutoGLM调度引擎深度解析&#xff1a;如何实现毫秒级城市资源响应&#xff1f;Open-AutoGLM作为新一代智能调度引擎&#xff0c;专为高并发、低延迟的城市级资源调度场景设计。其核心架构融合了实时图神经网络推理与动态负载预测模型&#xff0c;能够在…

作者头像 李华
网站建设 2026/4/29 7:53:03

从对话到预判:Open-AutoGLM如何实现驾驶员意图理解的跨越式突破

第一章&#xff1a;从对话到预判&#xff1a;Open-AutoGLM的演进之路Open-AutoGLM 的发展标志着大语言模型从被动响应向主动推理的重要跨越。早期版本聚焦于自然语言理解与生成&#xff0c;能够完成基础对话任务。随着应用场景复杂化&#xff0c;系统逐步引入上下文感知、多轮状…

作者头像 李华
网站建设 2026/4/29 10:19:21

Open-AutoGLM电子病历整理全攻略(从部署到上线仅需7步)

第一章&#xff1a;Open-AutoGLM电子病历整理辅助Open-AutoGLM 是一款专为医疗信息处理设计的开源大语言模型辅助工具&#xff0c;专注于提升电子病历&#xff08;EMR&#xff09;的整理效率与准确性。通过自然语言理解与结构化输出能力&#xff0c;该系统能够自动解析医生口述…

作者头像 李华