Un attacco Egghunter ha ancora senso in un sistema a 64 bit?

2

Sfondo

Un Egghunter è fondamentalmente uno stub di dimensioni ridotte che funge da primo stadio in un tentativo di sfruttamento a 2 stadi (mentre il secondo stadio è solitamente il codice shell malevolo del carico utile). Nella prima fase, lo stub cercherà attraverso il processo VAS (Virtual Address Space) per il payload del secondo stadio che viene immesso / iniettato altrove nella stessa memoria di processo. Una volta trovato, trasferisci il controllo nella seconda fase dello sfruttamento.

In un sistema x86, il VAS ha una dimensione di 4294967296 byte o circa 4 GB. È relativamente più facile effettuare la scansione dell'intero processo VAS di dimensione 4Gb.

Ora in un sistema x86_64 la dimensione VAS è fino a 16,8 milioni di Tb (Terabyte). Trovare un uovo in tale memoria sta davvero cercando di trovare un ago in un pagliaio.

Domanda:

Ciò rende irrilevante la tecnica di sfruttamento di egghunter in un sistema x86_64? Perché può essere molto difficile trovare l'etichetta dell'uovo ed eseguire il carico utile senza conoscere l'esatta posizione in tempo reale dell'uovo iniettato + carico utile

Difficoltà come:

  1. cercare in quella quantità di memoria potrebbe richiedere giorni / settimane
  2. UB quando le chiamate di sistema vengono ripetute per iterazioni [milioni x (Tb)]
  3. Segfault quando si verifica # 2

Quindi un attacco egghunter ha ancora senso in un attacco reale su un sistema a 64 bit, almeno senza conoscere la posizione esatta in memoria del payload del secondo stadio iniettato?

    
posta Rennitbaby 22.10.2018 - 06:25
fonte

1 risposta

1

Può avere senso, ma devi fare affidamento sulla fortuna. Così semplicemente, può funzionare ma non è davvero affidabile. Non è necessario cercare nell'intero spazio dell'indirizzo, poiché solo lo spazio utente è rilevante (47 bit). Se vuoi una spiegazione approfondita, questo articolo sperimenta questo attacco su un sistema a 64 bit. link

    
risposta data 23.10.2018 - 01:19
fonte

Leggi altre domande sui tag