|
|
(10 intermediate revisions by the same user not shown) |
Line 1: |
Line 1: |
− | = DRAFT CHEAT SHEET - WORK IN PROGRESS =
| + | Moved to [https://www.owasp.org/index.php/Clickjacking_Defense_Cheat_Sheet https://www.owasp.org/index.php/Clickjacking_Defense_Cheat_Sheet]. |
− | | |
− | = Introduction =
| |
− | | |
− | This article is focused on providing developer guidance on Clickjack/UI Redress attack prevention. For more information on the risk of Clickjacking, please visit [https://www.owasp.org/index.php/Clickjacking this page].
| |
− | | |
− | The most popular way to defend against clickjacking is to include some sort of "frame-breaking" functionality which prevents other web pages from framing the site you wish to defend. This cheat sheet will discuss two methods of implementing frame-braking; via X-FRAME-OPTIONS headers (if the browser or browsers in question support it) and via javascript "frame-breaking" code.
| |
− | | |
− | ==Defending with response headers==
| |
− | | |
− | ===X-FRAME-OPTIONS===
| |
− | ====Specifics====
| |
− | Thew X-FRAME-OPTIONS header is used to mark responses that should not be framed. There are three options with X-FRAME-OPTIONS.
| |
− | * The first is DENY, which prevents everyone from framing the content.
| |
− | * The second option is SAMEORIGIN, which only allows the current site to frame the content.
| |
− | * The third, is the ALLOW-FROM 'sitename' header, which permits the specified 'sitename' to frame this page. (e.g., ALLOW-FROM http://www.foo.com) The ALLOW-FROM option is a relatively recent addition (circa 2012) and may not be supported by all browsers yet.
| |
− | X-FRAME-OPTIONS has seen good adoption by major browsers, unfortunately studies have shown the header is [http://blogs.sans.org/appsecstreetfighter/2009/10/15/adoption-of-x-frame-options-header/ not yet widely deployed by sites].
| |
− | | |
− | ====Implementation====
| |
− | To implement this protection, you need to add the header to any page that you want to protect from being clickjacked. One way to do this is to add the header manually to every page. A possibly simpler way is to implement a filter that automatically adds the header to every page.
| |
− | | |
− | = References =
| |
− | | |
− | * Main OWASP [https://www.owasp.org/index.php/Clickjacking https://www.owasp.org/index.php/Clickjacking] page.
| |
− | * OWASP has an [[ClickjackFilter for Java EE|article and some code]] that provides all the details for implementing this in the Java EE environment.
| |
− | * The SDL blog has posted an [http://blogs.msdn.com/sdl/archive/2009/02/05/clickjacking-defense-in-ie8.aspx article] covering how to implement this in a .NET environment.
| |
− | * In 2009, Microsoft implemented a [http://blogs.msdn.com/ie/archive/2009/01/27/ie8-security-part-vii-clickjacking-defenses.aspx header based defense] in IE8 that allows developers to specify that pages should not be framed.
| |
− | | |
− | {{Cheatsheet_Navigation}}
| |
− | | |
− | [[Category:Cheatsheets]]
| |