Как разрешить тег iframe в `dompurify`, включая все его атрибуты - PullRequest
0 голосов
/ 19 февраля 2020

Я хочу dompurify, чтобы разрешить теги iframe, и я добавляю iframe в качестве исключения (ADD_TAGS). Но это удаляет некоторые атрибуты этого. Я хочу, чтобы все атрибуты были там.

<!doctype html>
<html>
    <head>
          <script src="https://cdnjs.cloudflare.com/ajax/libs/dompurify/1.0.3/purify.min.js"></script>    </head>
    <body>
        <!-- Our DIV to receive content -->
        <div id="sanitized"></div>

        <!-- Now let's sanitize that content -->
        <script>
            /* jshint globalstrict:true, multistr:true */
            /* global DOMPurify */
            'use strict';

            // Specify dirty HTML
            var dirty = '<iframe allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen="" frameborder="0" height="315" scrolling="no" src="https://www.youtube.com/embed/vJG698U2Mvo" width="560"></iframe>';

            var config = { ADD_TAGS: ['iframe'], KEEP_CONTENT: false }

            // Clean HTML string and write into our DIV
            var clean = DOMPurify.sanitize(dirty, config);
            console.log('clean: ', clean)
            document.getElementById('sanitized').innerHTML = clean;
        </script>
    </body>
</html>

Вот обработанный вывод

"clean: <iframe width='560' src='https://www.youtube.com/embed/vJG698U2Mvo' height='315'></iframe>"

1 Ответ

0 голосов
/ 19 февраля 2020

Если я правильно понимаю документацию, вам также необходимо зарегистрировать необходимые нестандартные атрибуты, которые вы хотите продолжать использовать:

DOMPurify.sanitize(dirty, { ADD_ATTR: ['allow', 'allowfullscreen', 'frameborder', 'scrolling'] });
...