动态转换图片格式为webp

简介: 动态转换图片格式为webp

前言


webp是谷歌推出的一种图像格式,它可以在保持同样质量的情况下,体积比JPG少40%,可以很大程度的节省带宽使用,提升网站的加载速度。


由于它是新推出不久的格式,对于一些比较旧的浏览器,它是不支持的。那么有没有办法让支持此格式的浏览器加载webp图片,让不支持的浏览器加载正常图片呢?


本文就跟大家分享一种解决方案,欢迎各位感兴趣的开发者阅读本文。


思路分析


我们想实现这个需求,首先得需要有一个能将普通的图片格式转换为webp格式的程序,经过一番寻找后,找到了一个名为webp_server_go的开源项目。


转换程序我们有了,那么如何动态调用这个程序呢?我们的需求是根据客户端的情况来决定是否要返回webp格式的图片,那么我们就可以在nginx中通过反向代理来实现动态调用。


我们来梳理下思路:


  • nginx拦截客户端请求,将请求反向代理到webp_server_go
  • webp_server_go收到请求后,读取http_header中的浏览器信息,决定是否要返回webp格式的图片
  • 最后,nginx将webp_server_go返回的内容发给浏览器


编译转换程序


webp_server_go的releases页面提供了linux的安装包,如果你的运行环境正好满足条件,可以跳过此章节,直接下载即可。


这个程序采用go语言编写,因此需要安装go的开发环境,由于安装过程较为简单,本文不做讲解。按照教程搭建好环境后,我们把项目clone到本地,目录如下所示:

640.png

                            image-20220518213243428


我们打开Makefile文件(推荐使用GoLand来打开),执行文件里面的default命令


640.png

                                image-20220518213515632


如果你的编辑器不支持点击图标来运行,那么你可以在终端进入项目的根目录,按照顺序执行如下所示的命令:


make clean
go build -o builds/webp-server-$(OS)-$(ARCH) .


执行成功后,你会在builds目录下看到编译出来的适用于你当前系统的应用程序(如果你的系统是macos,看到的结果会和我的一样,如果是windows看到的则是一个exe文件)。


640.png

                                   image-20220518214528472


运行转换程序


按照官网列举的使用方法,我们在用户的根目录创建一个名为webp-server的文件夹,将准备好的转换程序复制进去并在其目录下创建一个名为config.json文件,写入如下所示的内容:


  • HOST 启动后的服务地址
  • PORT 服务端口号
  • QUALITY 转换后的图片质量
  • MAX_JOB_COUNT 最大并发转换量
  • IMG_PATH 图片存储路径(客户端访问图片资源时的存储目录)
  • EXHAUST_PATH 转换为webp后的图片存储路径(客户端请求资源时会优先从这里找,找不到才会触发转换程序,转换完成后会存储到此处)
  • ALLOWED_TYPES 需要处理的图片格式


{
    "HOST": "127.0.0.1",
    "PORT": "8082",
    "QUALITY": "80",
    "MAX_JOB_COUNT": "10",
    "IMG_PATH": "/Volumes/DataStorage/fileStorage",
    "EXHAUST_PATH": "/Volumes/DataStorage/fileStorage/uploads/cache",
    "ALLOWED_TYPES": ["jpg", "png", "jpeg", "bmp"]
}


最后,在终端执行如下所示的命令来启动转换程序:


./webpServer --config=config.json


看到如下所示的界面时,就代表此服务已经正常工作了。


640.png

                                 image-20220518225743246


注意:大多数情况下你应该是需要此程序静默运行的,不希望看到这个运行框,那么你就需要用到nohup命令来执行程序了。

例如:nohup ./webpServer --config=config.json > /Volumes/DataStorage/logs/webpServer-log.txt &

对此命令不熟悉的开发者,请移步Linux nohup 命令作进一步了解。


反向代理客户端请求


做完上述配置后,我们就可以配置nginx来拦截客户端的请求,将其反向代理至我们上一步搭建的好服务上,配置如下所示:


  • 所有携带包含uploads的请求全部交给webpserver进行处理


# 反向代理uploads目录下的图片至webpserver进行格式转换
 location ~ ^/(uploads)/ {
   proxy_pass http://127.0.0.1:8082;
   proxy_set_header X-Real-IP $remote_addr;
    proxy_hide_header X-Powered-By;
    proxy_set_header HOST $http_host;
 }


最后,我们访问网站来看下是否成功,如下所示:


640.png

                               image-20220518231447321


返回的图片已经是webp格式了


640.png

                                 image-20220518231527544


写在最后


至此,文章就分享完毕了。


我是神奇的程序员,一位前端开发工程师。


  • 公众号无法外链,如果文中有链接,可点击下方阅读原文查看😊
相关文章
|
算法 C++ 索引
【C++STL基础入门】深入浅出string类查找字串、返回字串和交换操作
【C++STL基础入门】深入浅出string类查找字串、返回字串和交换操作
1071 1
|
11月前
|
机器学习/深度学习 人工智能 算法
VE-Bench:北京大学开源首个针对视频编辑质量的评估指标,从多角度考虑审美并准确地评估视频编辑效果
北京大学开源了首个针对视频编辑质量评估的新指标 VE-Bench,旨在通过人类感知一致的度量标准,更准确地评估视频编辑效果。
550 14
VE-Bench:北京大学开源首个针对视频编辑质量的评估指标,从多角度考虑审美并准确地评估视频编辑效果
|
前端开发 API UED
Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
296 2
|
Ubuntu 前端开发 Linux
Linux 发行版 Debian 宣布支持龙芯 LoongArch 架构
近期,龙芯发布了3A6000桌面处理器,芯片的性能又一次大幅度提升,成为国产芯片的又一里程碑。Debian 社区开发者邮件显示,Debian Ports 添加了对龙芯LoongArch 架构的支持。
799 0
|
开发框架 API 决策智能
ModelScope-Agent框架再升级!新增一键配置多人聊天,配套开源多智能体数据集和训练
ModelScope-Agent是魔搭社区推出的适配开源大语言模型(LLM)的AI Agent(智能体)开发框架,借助ModelScope-Agent,所有开发者都可基于开源 LLM 搭建属于自己的智能体应用。在最新升级完Assistant API和Tool APIs之后,我们又迎来了多智能体聊天室的升级,通过几分钟快速配置即可搭建一个全新的聊天室。
|
数据采集 分布式计算 前端开发
设置CDN防盗链规则来避免网站被恶意刷量
设置CDN防盗链规则来避免网站被恶意刷量
3472 1
|
监控 BI
财务智慧:全面解析ERP系统的财务管理模块
财务智慧:全面解析ERP系统的财务管理模块
1824 0
|
移动开发 前端开发 HTML5
『html5、css3』将视频做为网页背景 超炫!
效果图展示 仿墨迹天气首页 github项目地址:https://github.com/Ethan997/Video-background-page PC端网页效果预览:http://www.
5147 0
|
存储 消息中间件 资源调度
Flink state 详解
Flink state 详解
180 0
|
SQL 前端开发
MybatisPlus分页类型转换 不要在用循环转换了
MybatisPlus分页类型转换 不要在用循环转换了