进程保护--CrossThreadFlags标志位

原理:

1. 将进程的所有线程的线程CrossThreadFlags标志位设置成Terminated或者System.

效果:任务管理器,WSYSCheck,ICESWORD无法结束进程。。

但PCHunter 可以结束受保护的进程。但PCHunter无法用普通方法结束受保护的线程,必须使用强制结束线程才可结束线程。。

代码:

  1. VOID SetThreadFlagToTerminatedByThreadID(ULONG dwThreadID)
  2. {
  3. ULONG ulFlagOffset;
  4. NTSTATUS status = STATUS_UNSUCCESSFUL;
  5. PULONG pFlag;
  6. PETHREAD eThead;
  7. HANDLE threadHandle;
  8. __try{
  9. threadHandle = (HANDLE)dwThreadID;
  10. ulFlagOffset = GetCrossThreadFlagOffset();
  11. //dprintf("[ProtectProcess]GetCrossThreadFlagOffset: 0X%08X\r\n", ulFlagOffset);
  12. status = PsLookupThreadByThreadId(threadHandle, &eThead);
  13. if(!NT_SUCCESS(status))
  14. {
  15. dprintf("PsLookupThreadByThreadId ERRORid:0X%08X, TID: 0X%08X\r\n", status, dwThreadID);
  16. return status;
  17. }
  18. //dprintf("ETHREAD:0X%08X\n", eThead);
  19. pFlag = (ULONG*)((PUCHAR)eThead + ulFlagOffset);
  20. //dprintf("ulFlag address:0X%08X value:0x%08X\n", pFlag, *pFlag);
  21. *pFlag |= PS_CROSS_THREAD_FLAGS_TERMINATED;
  22. dprintf("new ulFlag address:0X%08X value:0x%08X\n", pFlag, *pFlag);
  23. }__except(EXCEPTION_EXECUTE_HANDLER)
  24. {
  25. dprintf("EXCEPTION ON set thread cross flags!");
  26. return status;
  27. }
  28. }
VOID SetThreadFlagToTerminatedByThreadID(ULONG dwThreadID)
{
ULONG ulFlagOffset;
NTSTATUS status = STATUS_UNSUCCESSFUL;
PULONG pFlag;
PETHREAD eThead;
HANDLE threadHandle; __try{
threadHandle = (HANDLE)dwThreadID;
ulFlagOffset = GetCrossThreadFlagOffset();
//dprintf("[ProtectProcess]GetCrossThreadFlagOffset: 0X%08X\r\n", ulFlagOffset); status = PsLookupThreadByThreadId(threadHandle, &eThead);
if(!NT_SUCCESS(status))
{ dprintf("PsLookupThreadByThreadId ERRORid:0X%08X, TID: 0X%08X\r\n", status, dwThreadID);
return status;
}
//dprintf("ETHREAD:0X%08X\n", eThead); pFlag = (ULONG*)((PUCHAR)eThead + ulFlagOffset);
//dprintf("ulFlag address:0X%08X value:0x%08X\n", pFlag, *pFlag); *pFlag |= PS_CROSS_THREAD_FLAGS_TERMINATED;
dprintf("new ulFlag address:0X%08X value:0x%08X\n", pFlag, *pFlag);
}__except(EXCEPTION_EXECUTE_HANDLER)
{
dprintf("EXCEPTION ON set thread cross flags!");
return status;
}
}

ring3程序与ring0程序下载地址:

http://download.csdn.net/detail/xiaocaiju/8192897

jpg改rar 进程保护--CrossThreadFlags标志位

上一篇:ls -alrth 及ls 详解


下一篇:Selenium UI 举例 getCssValue