看流星社区

 找回密码
 注册账号
查看: 2594|回复: 0

进程保护--CrossThreadFlags标志位

[复制链接]

该用户从未签到

发表于 2017-6-2 13:31:15 | 显示全部楼层 |阅读模式
原理:1. 将进程的所有线程的线程CrossThreadFlags标志位设置成Terminated或者System.效果:任务管理器,WSYSCheck,ICESWORD无法结束进程。。但PCHunter 可以结束受保护的进程。但PCHunter无法用普通方法结束受保护的线程,必须使用强制结束线程才可结束线程。。代码: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
点击按钮快速添加回复内容: 支持 高兴 激动 给力 加油 苦寻 生气 回帖 路过 感恩
您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

小黑屋|手机版|Archiver|看流星社区 |网站地图

GMT+8, 2024-4-26 01:27

Powered by Kanliuxing X3.4

© 2010-2019 kanliuxing.com

快速回复 返回顶部 返回列表