Skip to content

Instantly share code, notes, and snippets.

@oscarychen
Last active December 9, 2021 19:27

Revisions

  1. oscarychen revised this gist Dec 9, 2021. No changes.
  2. oscarychen revised this gist Dec 9, 2021. 1 changed file with 4 additions and 3 deletions.
    7 changes: 4 additions & 3 deletions xss.md
    Original file line number Diff line number Diff line change
    @@ -1,7 +1,5 @@
    # Cross-site scripting (XSS)

    _Based on [Feross Aboukhadijeh](https://feross.org)'s lectures ([1](https://youtu.be/XTcqlOFhpPI), [2](https://youtu.be/PlXzrtheQGc)) on web security at Stanford University._

    ## 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