Last active
December 9, 2021 19:27
Revisions
-
oscarychen revised this gist
Dec 9, 2021 . No changes.There are no files selected for viewing
-
oscarychen revised this gist
Dec 9, 2021 . 1 changed file with 4 additions and 3 deletions.There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,7 +1,5 @@ # Cross-site scripting (XSS) ## What is XSS? - Unexpected JavaScript code running in an HTML document @@ -65,4 +63,7 @@ Saves an HTTP request in a CSS file: `body { background-image: url(...' />`. Saves an HTTP request in a CSS file: `body { background-image: url(...); `. #### The `a`, `src`, and iframe `<a href='javascript:alert(document.cookie)'>Say hi</a>` `<iframe src='data:text/html,<script>alert(document.cookie)</script>'></iframe>` `<script src='data:application/javascript,alert(document.cookie)'></script>` #### the `on*` attributes `<div onmouseover='handleHover(USER_DATA_HERE)'>` `<div onmouseover='handleHover(); alert(document.cookie)'>` ## Mitigation - Defend user cookie: use `HttpOnly` cookie - Prevent site from being embedded by another site: use `X-Frame-Options` header - - X-Frame-Options not specified(default), any page can display this page in an iframe - - X-Frame-Options: deny - - X-Frame-Options: sameorigin - Prevent loading resources from another site: use Content Security Policy