前言
由于公司业务需求, 需要解决图片过大加载过慢的问题。这个问题呢首先给大家描述一下,起初是上传图片时将图片转换为base64保存至数据库存储的。 然后获取的时候会直接取出来base64转换图片展示,这样就发现上传的图片如果过大, 公司网络加载是会很慢的。 所以想到一个办法就是 上传时将图片压缩, 压缩后的和压缩之前的都保存下来。 然后默认展示压缩后的图片,然后点击图片时再去查出来原始图片的base64。最终博主找到可以利用thumbnailator对图片进行压缩。
正文
由于公司网络带宽差不多是100多kb,所以目前博主的设计方案是 如果图片大于128kb的话,就将图片压缩至128kb以下。我找到google有个插件thumbnailator可以满足我们的需求。 首先我们来看一下这个插件(Thumbnails类源码 of方法):
我们可以看到它的参数是源文件,也就是你初始的图片,准备编辑的图片。它有几个重载的方法,我们可以分别传入这些参数,我的项目需要用流,所以我传进去了一个ByteArrayInputStream对象。
他还有个方法是.scale()方法,它有两个重载:
单个参数的是宽高都按照相同的比例缩放。两个参数的方法var1是给宽度设置缩放比,var3是给高度设置缩放比。
最后一个是to*();这个方法是你压缩完之后,输出的格式,它有这几个方法:
这几个方法就可以满足我们的需求了。</