⚠️ This package is still experimental, common safe HTML tags & attributes as given in\TYPO3\HtmlSanitizer\Builder\CommonBuilder
still might be adjusted.
\TYPO3\HtmlSanitizer\Behavior
contains declarative settings for a particular process for sanitizing HTML.\TYPO3\HtmlSanitizer\Visitor\VisitorInterface
(multiple different visitors can exist at the same time) are actually doing the work based on the declaredBehavior
. Visitors can modify nodes or mark them for deletion.\TYPO3\HtmlSanitizer\Sanitizer
can be considered as the working instance, invoking visitors, parsing and serializing HTML. In general this instance does not contain much logic on how to handle particular nodes, attributes or values\TYPO3\HtmlSanitizer\Builder\BuilderInterface
can be used to create multiple different builder instances - in terms of "presets" - which combine declaring a particularBehavior
, initialization ofVisitorInterface
instances, and finally returning a ready-to-useSanitizer
instance
<?php
use TYPO3\HtmlSanitizer\Behavior;
use TYPO3\HtmlSanitizer\Sanitizer;
use TYPO3\HtmlSanitizer\Visitor\CommonVisitor;
require_once 'vendor/autoload.php';
$commonAttrs = [
new Behavior\Attr('id'),
new Behavior\Attr('class'),
new Behavior\Attr('data-', Behavior\Attr::NAME_PREFIX),
];
$hrefAttr = (new Behavior\Attr('href'))
->addValues(new Behavior\RegExpAttrValue('#^https?://#'));
// attention: only `Behavior` implementation uses immutability
// (invoking `withFlags()` or `withTags()` returns new instance)
$behavior = (new Behavior())
->withFlags(Behavior::ENCODE_INVALID_TAG)
->withTags(
(new Behavior\Tag('div', Behavior\Tag::ALLOW_CHILDREN))
->addAttrs(...$commonAttrs),
(new Behavior\Tag('a', Behavior\Tag::ALLOW_CHILDREN))
->addAttrs($hrefAttr, ...$commonAttrs),
(new Behavior\Tag('br')),
);
$visitors = [new CommonVisitor($behavior)];
$sanitizer = new Sanitizer(...$visitors);
$html = <<< EOH
<div id="main">
<a href="https://typo3.org/" data-type="url" wrong-attr="is-removed">TYPO3</a><br>
(the <span>SPAN, SPAN, SPAN</span> tag shall be encoded to HTML entities)
</div>
EOH;
echo $sanitizer->sanitize($html);
will result in the following sanitized output
<div id="main">
<a href="https://typo3.org/" data-type="url">TYPO3</a><br>
(the <span>SPAN, SPAN, SPAN</span> tag shall be encoded to HTML entities)
</div>
Behavior::ENCODE_INVALID_TAG
keeps invalid tags, but "disarms" them (see<span>
in example)Behavior::ENCODE_INVALID_ATTR
keeps invalid attributes, but "disarms" the whole(!) tagBehavior::REMOVE_UNEXPECTED_CHILDREN
removes children forTag
entities that were created without explicitly usingTag::ALLOW_CHILDREN
, but actually contained child nodesBehavior::ALLOW_CUSTOM_ELEMENTS
allow using custom elements (having a hyphen-
) - however, it is suggested to explicitly name all known and allowed tags and avoid using this flag
In general the TYPO3 core is released under the GNU General Public License version
2 or any later version (GPL-2.0-or-later
). In order to avoid licensing issues and
incompatibilities this package is licenced under the MIT License. In case you
duplicate or modify source code, credits are not required but really appreciated.
In case of finding additional security issues in the TYPO3 project or in this package in particular, please get in touch with the TYPO3 Security Team.