进程保护--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.   
  9.   
  10.     __try{  
  11.         threadHandle = (HANDLE)dwThreadID;  
  12.         ulFlagOffset = GetCrossThreadFlagOffset();  
  13.         //dprintf("[ProtectProcess]GetCrossThreadFlagOffset: 0X%08X\r\n", ulFlagOffset);  
  14.   
  15.         status = PsLookupThreadByThreadId(threadHandle, &eThead);  
  16.         if(!NT_SUCCESS(status))  
  17.         {  
  18.   
  19.             dprintf("PsLookupThreadByThreadId ERRORid:0X%08X, TID: 0X%08X\r\n", status, dwThreadID);  
  20.             return status;  
  21.         }  
  22.         //dprintf("ETHREAD:0X%08X\n", eThead);  
  23.   
  24.         pFlag = (ULONG*)((PUCHAR)eThead + ulFlagOffset);  
  25.         //dprintf("ulFlag address:0X%08X value:0x%08X\n", pFlag, *pFlag);  
  26.   
  27.         *pFlag |= PS_CROSS_THREAD_FLAGS_TERMINATED;  
  28.         dprintf("new ulFlag address:0X%08X value:0x%08X\n", pFlag, *pFlag);  
  29.     }__except(EXCEPTION_EXECUTE_HANDLER)  
  30.     {  
  31.         dprintf("EXCEPTION ON set thread cross flags!");  
  32.         return status;  
  33.     }  
  34. }  
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 

转载于:https://www.cnblogs.com/kuangke/p/7590790.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值