StripJs
StripJs is an Elixir module for stripping executable JavaScript from blocks of HTML and CSS.
It handles:
<script>...</script>and<script src="..."></script>tags-
Event handler attributes such as
onclick="..." javascript:...URLs in HTML and CSS-
CSS
expression(...)directives -
HTML entity attacks (like
<script>)
Usage
clean_html/2 removes all JS vectors from an HTML string:
iex> html = "<button onclick=\"alert('pwnt')\">Hi!</button>"
iex> StripJs.clean_html(html)
"<button>Hi!</button>"clean_css/2 removes all JS vectors from a CSS string:
iex> css = "body { background-image: url('javascript:alert()'); }"
iex> StripJs.clean_css(css)
"body { background-image: url('removed_by_strip_js:alert()'); }"Documentation
Full docs are available at Hexdocs.pm.
Authorship and License
Copyright 2017, Appcues, Inc.
StripJs is released under the MIT License.