使用Thumbnailator遇到异常:No suitable ImageReader found for source data

使用Thumbnailator工具完成对图片进行裁剪、缩放的处理:

java 复制代码
Thumbnails.of(file.getInputStream()).size(width, height).keepAspectRatio(false).toOutputStream(outputStream);

如果前端传入的是webp格式或者二进制文件,该文件中存储内容为将图片转成base64格式的字符串,部分内容如下:

java 复制代码
data:image/jpeg;base64,
iVBORw0KGgoAAAANSUhEUgAAAfUAAAH1CAYAAADvSGcRAAAAAXNSR0IArs4c6QAAAARnQU1BAACx
jwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAP+lSURBVHhetP3n927HsSf24ZKXOQcQBAkCIIic
c84555zTQc45HIRzkHMGiECQBC95Ge4lb5oZjUbyWNLSkrwsjzRjW7I9WsrWkkZakiz9Ae36fGv3
8zuc8fIbL7/otfezd+/u6uqq+lZV997PZt/dYd+x5Q7

会抛出异常:net.coobird.thumbnailator.tasks.UnsupportedFormatException: No suitable ImageReader found for source data.

原因是没有对应的图片解析器处理,那么解决办法有引入第三方依赖:

XML 复制代码
<dependency>
  <groupId>org.sejda.imageio</groupId>
  <artifactId>webp-imageio</artifactId>
  <version>0.1.6</version>
</dependency>

引入依赖后可能会解决第一种webp的问题,第二种问题依然无法解决,所以往往最普通的办法就是最使用的办法,这里通过最原始的流获取字节数组,将该字节数组读出到输出流并转换成字符串就是该二进制文件中所有的内容,即与原部分数据一致。

java 复制代码
public String ImageFileToBase64(MultipartFile multipartFile){
	String content;
	try {
        InputStream inputStream = multipartFile.getInputStream();
        //<1>创建字节数组输出流,用来输出读取到的内容
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        //<2>创建缓存大小
        byte[] buffer = new byte[1024]; // 1KB
        //每次读取到内容的长度
        int len = -1;
        //<3>开始读取输入流中的内容
        while ((len = inputStream.read(buffer)) != -1) { //当等于-1说明没有数据可以读取了
            baos.write(buffer, 0, len);   //把读取到的内容写到输出流中
        }
        //<4> 把字节数组转换为字符串
        content = baos.toString();
        //<5>关闭输入流和输出流
        inputStream.close();
        baos.close();
	}catch (Exception e){
    	log.error("文件解析错误",e);
    	throw new BusinessException(ErrorCode.SYSTEM_ERROR);
	}

	//<6>返回字符串结果
	return content;
}

再将data:image/jpeg;base64,过滤掉,

通过java原生的Base64.getDecoder().decode(),转换成字节数组的形式,

最后再使用new MockMultipartFile(),将字节数组转化为MultipartFile对象。

问题得以解决。其中contentType从data:image/jpeg;base64,中截取image/jpeg。

java 复制代码
String base64 = imageUtils.ImageFileToBase64(thumbnailFile);
String[] parts = base64.split(",");
String contentType = parts[0].split(";")[0].split(":")[1];
byte[] bytes = Base64.getDecoder().decode(parts[1]);
MultipartFile newThumbnailFile = new MockMultipartFile(thumbnailFile.getOriginalFilename(), thumbnailFile.getOriginalFilename(), contentType, bytes);

后续使用newThumbnailFile进行对文件的处理即可。

相关推荐
Dicky-_-zhang2 小时前
系统容量规划与压测实战:从1万到100万QPS的科学扩容
java·jvm
Highcharts.js7 小时前
倒置百分比堆叠面积图表示列详解|Highcharts大气成分图表代码
开发语言·信息可视化·highcharts·图表开发·面积图·图表示例·推叠图
csdn_aspnet8 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
Dicky-_-zhang8 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进
java·jvm
晨曦中的暮雨8 小时前
4.15腾讯 CSIG云服务产线 一面
java·开发语言
存在morning8 小时前
【GO语言开发实践】二 GO 并发快速上手
大数据·开发语言·golang
fake_ss1988 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法
茉莉玫瑰花茶8 小时前
工作流的常见模式 [ 1 ]
java·服务器·前端
未若君雅裁8 小时前
Spring AOP、日志切面与声明式事务原理
java·后端·spring
No8g攻城狮9 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9
java·数据库·spring boot·非关系型数据库