reactive-html-sanitizer
Reactive icon

Reactive Html Sanitizer

Stable version 1.1.0 (Compatible with OutSystems 11)
Uploaded
 on 26 November 2021
 by 
5.0
 (2 ratings)
reactive-html-sanitizer

Reactive Html Sanitizer

Details
Fast JavaScript customizable HTML Sanitizer, client-side (in the browser, no server actions required). This library can be used in OutSystems Reactive web applications, and also in Outsystems Mobile applications. It works also when the mobile application is offline.
Read more

Please note: to prevent XSS attacks you should always sanitize input on the server too. Never trust the client!

The sanitizer uses whitelisting approach (as opposed to "blacklisting") to clean out everything that's not allowed.

Speed

It uses browser/DOM to parse the html by creating an invisible "sandboxed" iframe (hence the browser "front-end only" requirement) which makes it much faster than "pure JavaScript" sanitizers, or server-side sanitizers.

Tags allowed by default

a, abbr, b, blockquote, body, br, center, code, div, em, font, h1, h2, h3, h4, h5, h6, hr, i, img, label, li, ol, p, pre, small, source, span, strong, table, tbody, tr, td, th, thead, ul, u, video

Attributes allowed by default

align, color, controls, height, href, src, style, target, title, type, width

CSS styles allowed by default

color, background-color, font-size, text-align, text-decoration, font-weight

BUT WHY?

Why create a front-end HTML sanitizer if the input has to be sanitized on the server anyway?

Users often copy-paste awful HTML generated by MS Word, MS Outlook or Apple Mail that needs a clean-up. Or you need to remove excessive formatting in a WYSIWYG editor. Or you need to display an (ugly) email message in a (beautiful) mobile app. Or (my favorite) you simply need to ease the load in the server-side sanitizer. And many many other use-cases.

Based on: https://github.com/jitbit/HtmlSanitizer

Release notes (1.1.0)

Text-decoration was used a shorthand CSS property, causing the property to always be removed from the html.

Text-decoration is now replaced by using all individual properties (text-decoration-line, text-decoration-color, text-decoration-style, text-decoration-thickness). 

Kudos to André Rodrigues, reporting this flaw in in my initial version.

Reviews (0)
Team
Other assets in this category