Web applications attacks/Cross site scripting
Description
data:image/s3,"s3://crabby-images/413bf/413bfdc73fe1f99f88f0f0d1c79575539909d366" alt=""
data:image/s3,"s3://crabby-images/5f1da/5f1daacec35ead8b0e117a4ea52e3e393c2894a0" alt=""
XSS attacks consists of modifying the normal behavior of a web application by injecting malicious code in it. Most of the time, it consists of JavaScript code that leads to transparent redirections, session theft, ...
Non-persistent XSS
An XSS attack will be considered as non persistent if it is not saved in the application (e.g. a mail containing a malicious script is sent).
Persistent XSS
As opposed to non-persistent attacks, attacks that are saved in the application (e.g. in the database, in files) are considered as persistent. Indeed, a user who connects to the application is likely to be impacted by the attack by displaying pages of the applications. An example of a persistent attack could be a message in a forum, containing an image which source is a remote malicious script.
Examples
Non persistent attacks
Persistent attacks
Protection
- Never trust data in the database. Data must be purified before being processed by the scripts.
- Never directly use data provided by the browser ($_GET, $_POST). Always purfiy these data before processing them.
Tools
- Arachni is a fast asynchronous Web Application Security Scanner that detects, among others, XSS vulnerabilities.
- XSS Me (Firefox plugin)
- XSSploit
- Watobo
- Zed Attack Proxy (ZAP)