跳至主要内容

WordPress网站免插件,一行代码实现:上传图片自动转为WebP格式 原创 FreeChao


 用一段php代码,免插件的方式,实现图片上传WordPress网站,自动将JPEG、PNG、GIF等转换为WebP格式图片。大大提高网站文章编辑的效率。之前我在写文章的时候,上传图片到网站的流程是先手动把本地的图片到一些站点,比如Squoosh、TinyPNG,进行WebP格式转化压缩,之后再手动上传到网站。这个过程实际上非常耗时,且机械重复没什么技术含量。一直想着有什么方法可以上传图片到网站的过程中自动就把这些活干了,省时省力。以前也尝试过一些插件,要么免费额度太少,要么过多的插件影响网站速度。 

 

  为什么要使用WebP格式的图片  

 WebP格式图片是由 Google 推出的一种现代图像格式,用来替代传统的图像格式如 JPEG、PNG、GIF 等。

 相比 JPEG、PNG和GIF,WebP 通常可以提供更小的文件大小,同时保持相似或更好的图像质量。

 较小的图片体积让网页加载更快,能够提高用户体验。快速加载的网页对 SEO(搜索引擎优化) 更好,提升网站在 Google、百度 等搜索引擎中的排名。

  自动转化WebP代码  

 代码功能说明:

  自动识别并将上传的图片jpeg、png、gif格式的图片转换为WebP格式

  图像质量为80%(如果要设置其他值,可更改代码中的 $quality = 80,建议值 70-90% )

  不保留原文件(如果要保留,删除或注释这个代码    @unlink($file_path);    )

/** * Convert Uploaded Images to WebP Format with Custom Quality */add_filter('wp_handle_upload', 'wpturbo_handle_upload_convert_to_webp');function wpturbo_handle_upload_convert_to_webp($upload) {    if (in_array($upload['type'], ['image/jpeg', 'image/png', 'image/gif'])) {        $file_path = $upload['file'];        if (extension_loaded('imagick') || extension_loaded('gd')) {            $image_editor = wp_get_image_editor($file_path);            if (!is_wp_error($image_editor)) {                // Set WebP quality (adjust as needed)$quality = 80; // Adjust between 0 (low) to 100 (high)                $image_editor->set_quality($quality); // Set quality for WebP conversion                $file_info = pathinfo($file_path);                $dirname = $file_info['dirname'];                $filename = $file_info['filename'];                $def_filename = wp_unique_filename($dirname, $filename . '.webp');                $new_file_path = $dirname . '/' . $def_filename;                $saved_image = $image_editor->save($new_file_path, 'image/webp');                if (!is_wp_error($saved_image) && file_exists($saved_image['path'])) {                    // Update the upload data to use the WebP image                    $upload['file'] = $saved_image['path'];                    $upload['url'] = str_replace(basename($upload['url']), basename($saved_image['path']), $upload['url']);                    $upload['type'] = 'image/webp';                    // Optionally delete the original file@unlink($file_path);                }            }        }    }    return $upload;}

 

 建议代码用Code Snippets、WPCode等插件进行统一管理。

  

  实际测试  

 上传前格式为PNG,大小为816kb

 

 上传后格式自动为WebP,大小为22kb,变化极其明显

  

 

评论

此博客中的热门博文

Cloudflare 的 1.1.1.1前世今生

  很多人第一次看到它,可能会觉得这是一串再普通不过的 IPv4 地址:四个 “1” 排列起来,简单好记。但实际上, 1.1.1.1 的地位,绝对不亚于 8.8.8.8 。它背后牵扯到互联网的基础设施、运营商、历史遗留问题,甚至还有一点江湖传说。

三步设置/3步搞定:Gmail新邮件秒推微信

  做外贸,Gmail是常用的沟通利器,但有时因为时差、忙碌或网络原因,没能及时查看邮件,可能就错过了重要信息。 其实,我们只要简单设置一下,就能让Gmail新邮件直接通过微信的“ QQ邮箱提醒 ”实时推送到 微信 ,这样我们就能第一时间在微信上收到通知,既方便又即时。

不花一分钱,用 Cloudflare Warp 免费实现科学上网 原创 W不懂安全

   在如今网络环境越来越复杂的情况下,很多人开始寻找安全、可靠、免费的科学上网方式。但动辄买 VPS、配置节点、折腾端口,对大多数人来说太麻烦。      其实你知道吗? Cloudflare 推出的      WARP       工具,只需要几步,就能让你       免费访问 Google、YouTube、ChatGPT 等国外网站       ,而且不需要任何技术背景、完全免费、跨平台支持(手机 +电脑都能用)!      如果你是学生党 / 打工人,想要上 Google 查资料、用 ChatGPT 学习、看看油管上的教程,但又不懂 VP恩、不想花钱买魔法……