Agli sviluppatori delle applicazioni che usano i database, ovviamente.
Dark Reading raccoglie in un articolo un decalogo di consigli per gli sviluppatori che vogliono mitigare i problemi di sicurezza delle applicazioni che utilizzano database (tipicamente SQL, ma non necessariamente).
Alcune norme sono ovvie e ne abbiamo parlato anche noi: la prima in assoluto è la SQL injection, molto più diffusa di quello che si possa credere. Basta, infatti, che un solo campo di un’intera applicazione non venga opportunamente sanificato per mettere a repentaglio la sicurezza dell’intero progetto.
Il secondo errore più comune commesso dagli sviluppatori è l’eccesso di informazioni di errore visualizzate all’utente. Ci dicono che non dobbiamo essere criptici nella messaggistica, però è anche bene evitare di esagerare per non rivelare involontariamente dati che potrebbero essere utili per un attacco mirato.
Un altro errore molto comune è l’abitudine di far collegare l’applicazione al database utilizzando privilegi elevati (super, sa, root…). Questa pessima abitudine è molto più comune negli applicativi commerciali (ad esempio i gestionali), che negli applicativi web. Questo perché, di solito, l’applicativo web viene installato in un contesto in cui la password di root del database non è disponibile, mentre il database server di un applicativo commerciale viene spesso installato dallo stesso fornitore con la presunzione di essere sempre l’unico ad usare un database su un host.
Non immaginate quanti database MSSQL di applicazioni commerciali vengono installati con sa senza password o con password sa.
L’articolo cita altri esempi, che valgono la pena di essere letti per verificare se, per le cause più diverse, abbiamo in giro applicazioni vulnerabili. (via Jennifer Manguino)
4 risposte a “La sicurezza dei database è in mano agli sviluppatori”
Quando leggo certe cose SUDO…
Sino a quando consideriamo “programmatori” dei mononeuronici che sanno come mettere in sequenza 4 comandi di un qualsiasi linguaggio…
K.
Verissimo, giusto qualche tempo addietro installavamo un gestionale dove sono HARDCODED username “root” e password “nome del gestionale” per il database mysql. Non e` possibile usare un login diverso o una password diversa.
E` una buona top-10, ma preferisco la OWASP: https://www.owasp.org/index.php/Top_10_2010