首页 > 解决方案 > Laravel HTMLPurifier 过滤 base64 编码图像

问题描述

我正在使用 Laravel HTMLPurifer 过滤由 ckeditor 表单输入的内容。

但是,默认配置是过滤图像内容为 base64 编码的 src 的图像。

我查看了这些链接,但其中提供的解决方案对我不起作用:

这些建议的主要问题是它们使用 HTMLPurifier 包而不是 Mews Laravel HTMLPurifier 包。这个问题描述了类似的情况Laravel Mews HTMLPurifier - add custom config

我试过这个配置:

return [
'encoding'      => 'UTF-8',
'finalize'      => true,
'cachePath'     => storage_path('app/purifier'),
'cacheFileMode' => 0755,
'settings'      => [
    'default' => [
        'HTML.Doctype'             => 'HTML 4.01 Transitional',
        'HTML.Allowed'             => 'div,b,strong,i,em,u,a[href|title],ul,ol,li,p[style],br,span[style],img[width|height|alt|src],table[border|width|style],tbody,tr,td,th,blockquote',
        'CSS.AllowedProperties'    => 'font,font-size,font-weight,font-style,font-family,text-decoration,padding-left,color,background-color,text-align',
        'AutoFormat.AutoParagraph' => true,
        'AutoFormat.RemoveEmpty'   => true,
    ],
    'test'    => [
        'Attr.EnableID' => 'true',
    ],
    'URI' => [
        'AllowedSchemes' => [
            'data' => true
        ],
    ],
    "youtube" => [
        "HTML.SafeIframe"      => 'true',
        "URI.SafeIframeRegexp" => "%^(http://|https://|//)(www.youtube.com/embed/|player.vimeo.com/video/)%",
    ],
    'custom_definition' => [
        'id'  => 'html5-definitions',
        'rev' => 1,
        'debug' => false,
        'elements' => [
            // http://developers.whatwg.org/sections.html
            ['section', 'Block', 'Flow', 'Common'],
            ['nav',     'Block', 'Flow', 'Common'],
            ['article', 'Block', 'Flow', 'Common'],
            ['aside',   'Block', 'Flow', 'Common'],
            ['header',  'Block', 'Flow', 'Common'],
            ['footer',  'Block', 'Flow', 'Common'],

            // Content model actually excludes several tags, not modelled here
            ['address', 'Block', 'Flow', 'Common'],
            ['hgroup', 'Block', 'Required: h1 | h2 | h3 | h4 | h5 | h6', 'Common'],

            // http://developers.whatwg.org/grouping-content.html
            ['figure', 'Block', 'Optional: (figcaption, Flow) | (Flow, figcaption) | Flow', 'Common'],
            ['figcaption', 'Inline', 'Flow', 'Common'],

            // http://developers.whatwg.org/the-video-element.html#the-video-element
            ['video', 'Block', 'Optional: (source, Flow) | (Flow, source) | Flow', 'Common', [
                'src' => 'URI',
                'type' => 'Text',
                'width' => 'Length',
                'height' => 'Length',
                'poster' => 'URI',
                'preload' => 'Enum#auto,metadata,none',
                'controls' => 'Bool',
            ]],
            ['source', 'Block', 'Flow', 'Common', [
                'src' => 'URI',
                'type' => 'Text',
            ]],

            // http://developers.whatwg.org/text-level-semantics.html
            ['s',    'Inline', 'Inline', 'Common'],
            ['var',  'Inline', 'Inline', 'Common'],
            ['sub',  'Inline', 'Inline', 'Common'],
            ['sup',  'Inline', 'Inline', 'Common'],
            ['mark', 'Inline', 'Inline', 'Common'],
            ['wbr',  'Inline', 'Empty', 'Core'],

            // http://developers.whatwg.org/edits.html
            ['ins', 'Block', 'Flow', 'Common', ['cite' => 'URI', 'datetime' => 'CDATA']],
            ['del', 'Block', 'Flow', 'Common', ['cite' => 'URI', 'datetime' => 'CDATA']],
        ],
        'attributes' => [
            ['iframe', 'allowfullscreen', 'Bool'],
            ['table', 'height', 'Text'],
            ['td', 'border', 'Text'],
            ['th', 'border', 'Text'],
            ['tr', 'width', 'Text'],
            ['tr', 'height', 'Text'],
            ['tr', 'border', 'Text'],
        ],
    ],
    'custom_attributes' => [
        ['a', 'target', 'Enum#_blank,_self,_target,_top'],
    ],
    'custom_elements' => [
        ['u', 'Inline', 'Inline', 'Common'],
    ],
],

];

任何帮助表示赞赏。

标签: phplaravelhtmlpurifier

解决方案


原来问题在于 URI.AllowedSchemes 被放置在错误的部分。

    return [
    'encoding'      => 'UTF-8',
    'finalize'      => true,
    'cachePath'     => storage_path('app/purifier'),
    'cacheFileMode' => 0755,
    'settings'      => [
        'default' => [
            'HTML.Doctype'             => 'HTML 4.01 Transitional',
            'HTML.Allowed'             => 'div,b,strong,i,em,u,a[href|title],ul,ol,li,p[style],br,span[style],img[width|height|alt|src],table[border|width|style],tbody,tr,td,th,blockquote',
            'CSS.AllowedProperties'    => 'font,font-size,font-weight,font-style,font-family,text-decoration,padding-left,color,background-color,text-align',
            'AutoFormat.AutoParagraph' => true,
            'AutoFormat.RemoveEmpty'   => true,
            'URI.AllowedSchemes' => [
                'data' => true
            ],
        ],
        'test'    => [
            'Attr.EnableID' => 'true',
        ],
        "youtube" => [
            "HTML.SafeIframe"      => 'true',
            "URI.SafeIframeRegexp" => "%^(http://|https://|//)(www.youtube.com/embed/|player.vimeo.com/video/)%",
        ],
        'custom_definition' => [
            'id'  => 'html5-definitions',
            'rev' => 1,
            'debug' => false,
            'elements' => [
                // http://developers.whatwg.org/sections.html
                ['section', 'Block', 'Flow', 'Common'],
                ['nav',     'Block', 'Flow', 'Common'],
                ['article', 'Block', 'Flow', 'Common'],
                ['aside',   'Block', 'Flow', 'Common'],
                ['header',  'Block', 'Flow', 'Common'],
                ['footer',  'Block', 'Flow', 'Common'],

                // Content model actually excludes several tags, not modelled here
                ['address', 'Block', 'Flow', 'Common'],
                ['hgroup', 'Block', 'Required: h1 | h2 | h3 | h4 | h5 | h6', 'Common'],

                // http://developers.whatwg.org/grouping-content.html
                ['figure', 'Block', 'Optional: (figcaption, Flow) | (Flow, figcaption) | Flow', 'Common'],
                ['figcaption', 'Inline', 'Flow', 'Common'],

                // http://developers.whatwg.org/the-video-element.html#the-video-element
                ['video', 'Block', 'Optional: (source, Flow) | (Flow, source) | Flow', 'Common', [
                    'src' => 'URI',
                    'type' => 'Text',
                    'width' => 'Length',
                    'height' => 'Length',
                    'poster' => 'URI',
                    'preload' => 'Enum#auto,metadata,none',
                    'controls' => 'Bool',
                ]],
                ['source', 'Block', 'Flow', 'Common', [
                    'src' => 'URI',
                    'type' => 'Text',
                ]],

                // http://developers.whatwg.org/text-level-semantics.html
                ['s',    'Inline', 'Inline', 'Common'],
                ['var',  'Inline', 'Inline', 'Common'],
                ['sub',  'Inline', 'Inline', 'Common'],
                ['sup',  'Inline', 'Inline', 'Common'],
                ['mark', 'Inline', 'Inline', 'Common'],
                ['wbr',  'Inline', 'Empty', 'Core'],

                // http://developers.whatwg.org/edits.html
                ['ins', 'Block', 'Flow', 'Common', ['cite' => 'URI', 'datetime' => 'CDATA']],
                ['del', 'Block', 'Flow', 'Common', ['cite' => 'URI', 'datetime' => 'CDATA']],
            ],
            'attributes' => [
                ['iframe', 'allowfullscreen', 'Bool'],
                ['table', 'height', 'Text'],
                ['td', 'border', 'Text'],
                ['th', 'border', 'Text'],
                ['tr', 'width', 'Text'],
                ['tr', 'height', 'Text'],
                ['tr', 'border', 'Text'],
            ],
        ],
        'custom_attributes' => [
            ['a', 'target', 'Enum#_blank,_self,_target,_top'],
        ],
        'custom_elements' => [
            ['u', 'Inline', 'Inline', 'Common'],
        ],
    ],
]

推荐阅读