为WordPress启用SVG支持,允许上传SVG图像

首页 » 实用教程 » 为WordPress启用SVG支持,允许上传SVG图像
所属分类:实用教程
发布时间:2022-06-17
浏览次数:22 views

SVG作为一种通用的矢量图格式,已经被主流浏览器支持,目前,WordPress还没有内置SVG支持,所以用户无法直接上传SVG图像到WordPress文章或媒体库中,实在理解不了。虽然允许嵌入JavaScript代码会带来一些安全性问题,但也不是没有办法解决,如果仅仅因为这一点而不支持SVG,实在有点太难受了。

不过好在WordPress是一个非常开放的程序,虽然WordPress默认不支持上传SVG图像,但是我们可以通过一些办法(代码)来为我们的网站后台添加上这个功能。

一、通过代码为WordPress添加SVG支持

下面是允许在WordPress中上传SVG图像的代码,简单的添加到主题的functions.php文件或插件文件中即可为WordPress启用SVG支持。

add_filter('wp_check_filetype_and_ext', function ($data, $file, $filename, $mimes)
{
    global $wp_version;

    if ($wp_version !== '4.7.1') {
        return $data;
    }

    $filetype = wp_check_filetype($filename, $mimes);

    return [
        'ext'             => $filetype[ 'ext' ],
        'type'            => $filetype[ 'type' ],
        'proper_filename' => $data[ 'proper_filename' ],
    ];

}, 10, 4);


add_filter('upload_mimes', function ($mimes)
{
    $mimes[ 'svg' ] = 'image/svg+xml';

    return $mimes;
});


add_action('admin_head', function ()
{
    echo '<style>
        .attachment-266x266, .thumbnail img {
             width: 100% !important;
             height: auto !important;
        }
        </style>';
});

使用这种方法为WordPress添加SVG支持没有安全检查,不建议使用在多用户WordPress站点中。

二、通过插件为WordPress启用SVG支持

使用Safe SVG插件为WordPress添加SVG支持简单方法,推荐大家都使用这种方法来实现。这个插件除了能启用WordPress支持,还会对上传的SVG文件进行清理和验证,以阻止可能影响网站的SVG漏洞。

Safe SVG插件的安全处理功能是通过svg-sanitizer库实现的,如果您有代码洁癖,想在自己的主题或插件中集成SVG支持,可以参考Safe SVG插件实现安全处理功能。

三、其他为WordPress启用SVG支持的方法

除此之外,流行的Elementor编辑器也内置了启用SVG支持的功能,不过貌似只能在Elementor编辑器中上传SVG、无法在默认的媒体库中上传。

如果您还有其他为WordPress启用SVG支持的方法,欢迎在本文的评论中留言提出。

关键字:

相关阅读

为wordpress分类、页面和标签页固定链接添加.html后缀

大家可能都知道,通过设置固定链接格式,可将wordpress日志URL设置成伪静态的形式。 同样通过之前介绍的 […]

WordPress定时发布——让搜索引擎和访客爱上你

预知未来的魅力 新浪微博的皮皮时光机很受欢迎,你是个微博funs,想吸引人气,又不想一次把肚子里的墨水吐干净, […]

常用 JavaScript 库 CDN 加速服务

作为开发者,你一定对 Google CDN 不陌生,微软也有 Microsoft Ajax CDN,他们都提供 […]