27/02/2012

Tipi di attacco CSRF

In questo post ho descritto il concetto su cui si basa l'attacco CSRF, mentre in quest'altro post ho provato ad elencare alcuni rimedi da utilizzare per mitigare tale tipologia di attacco.

 

csrf,refrected,login,stored,token,html,form,javascript,xss

Adesso vedremo quali sono i diversi tipi di attacco CSRF.

Login CSRF

L'attaccante invia una URL trappola alla vittima, contenente le proprie credenziali di accesso sul sito vulnerabile. In questo modo, appena la vittima effettuerà il login e se il sito lo consente, l'attaccante riuscirà a tenere traccia dei suoi comportamenti (sezioni visitate, link cliccati et similia), semplicemente accedendo al proprio profilo in un secondo momento (vedi YouTube).

Stored CSRF

Il sito vulnerabile consente l'inserimento di codice lato client (Javascript e/o HTML) da parte degli utenti autenticati. Questa in realtà è una vulnerabilità agli attacchi XSS che però può essere utilizzata per creare delle richieste CSRF. Supponiamo che l'attaccante utilizzi i campi di input di un form per iniettare del codice HTML contenente un ulteriore form caratterizzato da diversi campi hidden. Tali campi verranno popolati ad-hoc in modo da creare le giuste variabili da inviare al server tramite HTTP POST.

Ad esempio si potrebbe avere un form del tipo:

<form name="csrf" id="csrf" method="post" action="pagina.php">
<input type="hidden" name="nome" value="Mario" />
<input type="hidden" name="cognome" value="Rossi" />
<input type="hidden" name="telefono" value="06676785" />
</form>

e la seguente immagine "trappola":

<img src="images/immagine.jpg" alt="immagine" onclick="javascript:document.forms['csrf'].submit()" />

L'utente vittima, cliccando sull'immagine, invierebbe i dati al server, i quali verrebbero così processati (si pensi alla classica transazione finanziaria).

Tale tipologia di attacco CSRF è quella che ha un ottimo margine di riuscita, in quanto l'attaccante è certo che l'utente vittima sia effettivamente loggato al sito vulnerabile (altrimenti non potrebbe accedere al form precedentemente forgiato).

Reflected CSRF

L'attacco ha come sorgente "terze parti", ad esempio siti esterni, applicazioni di instant messaging, client di posta et similia. I margini di riuscita sono relativamente bassi, in quanto l'attaccante non può sapere a priori se la vittima è loggata o meno sul sito vulnerabile nel momento in cui viene sferrato l'attacco vero e proprio.

Le metodologie di attacco sono quelle classiche, ovvero creazione di una URL "trappola" oppure l'uso di un form creato ad hoc.

Il form che l'attaccante potrebbe creare è simile a quello visto in precedenza, eccezion fatta per l'attributo action:

<form name="csrf" id="csrf" method="post" action="http://www.sitovulnerabile.it/pagina.php">
<input type="hidden" name="nome" value="Mario" />
<input type="hidden" name="cognome" value="Rossi" />
<input type="hidden" name="telefono" value="06676785" />
</form>

<img src="images/immagine.jpg" alt="immagine" onclick="javascript:document.forms['csrf'].submit()" />

Dai miei esempi si evince come l'HTTP POST offra dei margini di sicurezza migliori rispetto al GET, ma è comunque soggetto ad attacchi CSRF. Per questo, è opportuno utilizzare il token anche se il vostro sito accetta solo dati inviati mediante POST.

Inoltre, nell'ambito degli stored CSRF, se il sito non presenta vulnerabilità XSS (grazie a politiche di input sanitization), il metodo POST associato al controllo del referer HTTP, rappresenta una buona contromisura al CSRF, anche se non ottimale.

Proprio per questo motivo, consiglio di utilizzare i token sempre e comunque.

A presto.

10:00 Scritto da: nazarenolatella in Sicurezza | Link permanente | Commenti (0) | Segnala | Tag: csrf, refrected, login, stored, token, html, form, javascript, xss | OKNOtizie |  Facebook

23/03/2011

Creare un utente locale per il login su dispositivi cisco

Recentemente mi è capitato di dover creare un nuovo utente locale che potesse loggarsi (via vty, console oppure aux) su un router Cisco 2851. Per fare ciò mi è bastato digitare il comando:

Router(config)# username <vostro username> privilege 15 secret <vostra password>

2851.jpg

 

Affinchè tale comando abbia effetto, è necessario che sia specificato il login local per ogni line, ad esempio:

Router(config)# line console 0

Router(config-line)# login local

Router(config)# line vty 0 4

Router(config-line)# login local

e così via.

Lanciamo infine un copy run start per salvare le nuove impostazioni ed il gioco è fatto.

Fine del post, a presto.

20:02 Scritto da: nazarenolatella in learning log | Link permanente | Commenti (0) | Segnala | Tag: cisco, network, login, user, username, local | OKNOtizie |  Facebook

11/02/2010

Apache 2: abilitare username e password per accedere alle pagine Web

Spesso si rende necessario abilitare sul server Web Apache un meccanismo di autenticazione dell'utente, in modo da consentire la visualizzazione delle pagine solo ad una cerchia ristretta di visitatori.

Per fare ciò occorre dapprima creare nome utente e password mediante un tool molto potente ed allo stesso tempo flessibile, ovvero htpasswd:

nightfly@nightbox:~$ sudo htpasswd -c /etc/apache2/passwd utenteabilitato

dove utenteabilitato è lo username e passwd presente in /etc/apache2 è il file in cui è contenuto il digest della password.

A questo punto creiamo il file .htaccess e posizioniamolo nella cartella che vogliamo proteggere, ad esempio prova:

nightfly@nightbox:~$ cd /var/www/prova

nightfly@nightbox:~$ sudo nano .htaccess

Inseriamo all'interno del file in questione le seguenti stringhe:

AuthName "Sezione riservata"
AuthType Basic
AuthUserFile /etc/apache2/passwd
Require valid-user

Infine accediamo al file apache2.conf presente nella DIR /etc/apache2:

nightfly@nightbox:~$ sudo nano /etc/apache2/apache2.conf

ed inseriamo i seguenti parametri:

<Directory /var/www/prova>
AllowOverride AuthConfig
</Directory>

Riavviamo Apache con il comando:

nightfly@nightbox:~$ sudo /etc/init.d/apache2 restart

e da ora in poi il tentativo di visualizzazione delle pagine contenute nella cartella prova verrà preceduto da una richiesta di username e password.

La mini guida termina qui. A presto.