Web applications are becoming the dominant way to provide access to on-line services. At the same time, web application vulnerabilities are being discovered and disclosed at an alarming rate. Web applications often make use of JavaScript code that is embedded into web pages to support dynamic client-side behavior. This script code is executed in the context of the user's web browser. To protect the user's environment from malicious JavaScript code, a sand-boxing mechanism is used that limits a program to access only resources associated with its origin site. Unfortunately, these security mechanisms fail if a user can be lured into downloading malicious JavaScript code from an intermediate, trusted site. In this case, the malicious script is granted full access to all resources (e.g., authentication tokens and cookies) that belong to the trusted site. Such attacks are called cross-site scripting (XSS) attacks.In general, XSS attacks are easy to execute, but difficult to detect and prevent. One reason is the high flexibility of HTML encoding schemes, offering the attacker many possibilities for circumventing server-side input filters that should prevent malicious scripts from being injected into trusted sites. Also, devising a client-side solution is not easy because of the difficulty of identifying JavaScript code as being malicious. This paper presents Noxes, which is, to the best of our knowledge, the first client-side solution to mitigate cross-site scripting attacks. Noxes acts as a web proxy and uses both manual and automatically generated rules to mitigate possible cross-site scripting attempts. Noxes effectively protects against information leakage from the user's environment while requiring minimal user interaction and customization effort.
[1]
Steven Cook.
A Web Developer's Guide to Cross-Site Scripting
,
2003
.
[2]
Richard Sharp,et al.
Abstracting application-level web security
,
2002,
WWW.
[3]
Shih-Kun Huang,et al.
Web application security assessment by fault injection and behavior monitoring
,
2003,
WWW '03.
[4]
D. T. Lee,et al.
Securing web application code by static analysis and runtime protection
,
2004,
WWW '04.
[5]
David Endler,et al.
The Evolution of Cross Site Scripting Attacks
,
2002
.
[6]
D. Flannanghan.
JavaScript: The definitive guide
,
1999
.