Java解析上传的zip文件--包含Excel解析与图片上传

前言:今天遇到一个需求:上传一个zip格式的压缩文件,该zip中包含人员信息的excel以及excel中每行对应的人的图片,现在需要将该zip压缩包中所有内容解析导入到数据库中,包括图片,并将图片与excel内容对应。

代码演示:

/**
* 信息导入Controller
*/
@RestController
@RequestMapping("/import")
public class ImportController { @AutoWired
private IExcelService excelService /**
* 接收zip
* zip中包含了人员excel以及excel中每行对应的人员图片--默认每个人员图片的名称为number号
*/
@PostMapping(value = "/zip")
@Transactional
public void sendRequest(@RequestParam("file") MultipartFile zipFile) throws IOException {
//通过zip名称创建一个file文件-该文件无具体路径
File file = new File(Objects.requireNonNull(zipFile.getOriginalFilename()));
//将zip写入到file中
FileUtils.writeByteArrayToFile(file, zipFileFile.getBytes());
//设定字符集编码--这一步必须,否则放到linux服务器中会有字符集报错
Charset charset = Charset.forName("GBK");
ZipFile zipFile = new ZipFile(file, charset);
//开始读取zip中文件
Enumeration<? extends ZipEntry> entries = zipFile.entries();
//创建excelZip存放zip中的excel文件内容
List<ZipEntry> excelZip = new ArrayList<ZipEntry>();
//创建imgZip存放zip中的图片文件
List<ZipEntry> imgZip = new ArrayList<ZipEntry>(); //开始读取zip文件
while (entries.hasMoreElements()) {
ZipEntry entry = entries.nextElement();
//通过文件名称去过滤出excel
if (entry.getName().contains("/excel表格名称.xlsx")) {
excelZip.add(entry);
}
//获取包含图片目录下所有的图片信息
if (!entry.isDirectory() && entry.getName().contains("图片目录的名称")) {
imgZip.add(entry);
}
}
//创建文件输入流,将excel变为流
InputStream excelInputStream = zipFile.getInputStream(excelZip.get(0));
//创建EasyExcel中的监听器
ExcelListener excelListener = new ExcelListener();
//调用EasyExcel中的EasyExcelFactory方法去读取输入流
EasyExcelFactory.read(excelInputStream,Excel.class,excelListener).sheet().doRead();
//到此完成获取压缩包中excel的人员信息
List<Excel> excelList = excelListener.getDataList(); //遍历读取图片
imgZip.stream().forEach(zip -> {
try {
//创建压缩图片的输入流
InputStream imgInputStream = zipFile.getInputStream(zip);
//调用流转文件的方法
File img = stream2file(imgInputStream);
for (Excel excel : excelList)
{
//将去除后缀的压缩图片名称与excel中的人员号码字段做比较
if (removeExtension(zip.getName()).contains(excel.getNum())) {
//调用文件上传接口,上传到服务器目录下,并返回文件存储路径
//这边FileUpload.upload为自己写的一个上传接口,此处省略。。。
//如果接受对象为MultipartFile,还需调用fileToMultipartFile转换
String urlPath =FileUpload.upload(fileToMultipartFile(img));
//进行对象的保存
Excel e=new Excel();
//设置存储的图片地址
e.setPath(urlPath);
//调用存储接口存储图片与excel信息
excelService.insert(e);
}
}
} catch (IOException e) {
throw new RuntimeException(e);
}
});
} //设置文件名前缀;必须至少三个字符
static final String PREFIX = "stream2file";
//设置定义文件的后缀扩展名;如果为null,则将使用后缀".tmp"
//这边为图片格式,所以默认给的后缀为jpg格式
static final String SUFFIX = ".jpg"; /**
* 输入流转文件
* 该方法为在内存中创建临时文件,不进行磁盘存储
*/
public static File stream2file(InputStream in) throws IOException {
//创建临时文件
final File tempFile = File.createTempFile(PREFIX, SUFFIX);
tempFile.deleteOnExit();
try (FileOutputStream out = new FileOutputStream(tempFile)) {
IOUtils.copy(in, out);
}
return tempFile;
} /**
* 截取文件名称--去除后缀名(.jpg等)
*/
public static String removeExtension(String fileName) {
int lastDotIndex = fileName.lastIndexOf('.');
if (lastDotIndex == -1) {
// 如果文件名中没有后缀,则返回原文件名
return fileName;
} else {
// 截取从开头到最后一个`.`字符之前的部分
return fileName.substring(0, lastDotIndex);
}
} /**
* file转MultipartFile
*
* @param file file
* @return MultipartFile
*/
public static MultipartFile fileToMultipartFile(File file) {
MultipartFile result = null;
if (null != file) {
try (FileInputStream input = new FileInputStream(file)) {
result = new MockMultipartFile(file.getName().concat("temp"), file.getName(), "text/plain", input);
} catch (IOException e) {
e.printStackTrace();
}
}
return result;
}
}
}

回顾:

博主解答思路为:

  1. 接收压缩文件
  2. 解析压缩文件,并区分excel与图片文件
  3. 将excel与图片进行匹配,将匹配成功的数据存储到数据库中

要点:

  1. 本次读取几乎都是内存读取,将数据读取到内存中,也在磁盘中建立了临时文件
  2. 解析时需要进行多次类型转换
  3. new ZipFile(file, charset)这一步一定要设定字符集编码,并查看window与linux字符集编码的区别,否则会因为字符集编码问题报错而无法运行

Java解析上传的zip文件--包含Excel解析与图片上传的更多相关文章

  1. Java 上传解压zip文件,并且解析文件里面的excel和图片

    需求:上传一个zip文件,zip文件里面包含一个excel和很多图片,需要把excel里面的信息解析出来保存到表中,同时图片也转化成base64保存到数据库表中. PS:为了方便不同水平的开发人员阅读 ...

  2. 解压上传的zip文件流和文件

    /** * 解压上传的zip文件流 * @param stream * @param outputDirectory */ public static String unzip(InputStream ...

  3. Java使用基本JDK操作ZIP文件以及zip文件的加密、解密等功能

    Java使用基本JDK操作ZIP文件 http://blog.csdn.net/zhyh1986/article/details/7723649 Java解压和压缩带密码的zip文件 http://b ...

  4. 历史上的今天mysql数据库包含详情分类以及图片

    历史上的今天mysql数据库包含详情分类以及图片 https://item.taobao.com/item.htm?spm=a2oq0.12575281.0.0.50111debo71iaJ& ...

  5. 用html5文件api实现移动端图片上传&预览效果

    想要用h5在移动端实现图片上传&预览效果,首先要了解html5的文件api相关知识(所有api只列举本功能所需): 1.Blob对象  Blob表示原始二进制数据,Html5的file对象就继 ...

  6. java解压多目录Zip文件(解决中文乱码问题)--转载

    原文地址:http://zhangyongbo.iteye.com/blog/1749439 import java.io.BufferedOutputStream; import java.io.F ...

  7. JAVA解压.Z及.ZIP文件

    <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-compress --> <dependency ...

  8. 包含修改字体,图片上传等功能的文本输入框-Bootstrap

    通过jQuery Bootstrap小插件,框任何一个div转换变成一个富文本编辑框,主要特色: 在Mac和window平台下自动针对常用操作绑定热键 可以拖拽插入图片,支持图片上传(也可以获取移动设 ...

  9. JAVA通过FTP方式向远程服务器或者客户端上传、下载文件,以及删除FTP服务器上的文件

    1.在目标服务器上搭建FTP服务器 搭建方式有多种大家可以自行选择,例如使用Serv-U或者FTPServer.exe:这里我以FTPServer.exe为例搭建:在目标服务器(这里对应的IP是10. ...

  10. 【java】System.out重定向到文件,并重定向会console上

    重定向到文件: System.setOut(new PrintStream(new File("data\\train.1.scale"))); 重定向回console: //把输 ...

随机推荐

  1. 系统监控:使用日志文件 journalctl的使用

    journalctl 显示最近登录的: 上面有最近登录的时间,和系统操作 几十年来,Linux日志记录一直由syslogd守护进程管理.Syslogd将收集系统处理和应用程序发送到/dev/log伪设 ...

  2. VBA常用的函数

    space(8)加空格 vbcrlf换行 trim()去掉两侧空格 lrim()去掉左侧空格 rtrim()去掉右侧空格 left()取字符的左侧 right()取字符串的右侧开始 mid()取字符串 ...

  3. Filter拦截问题

    关于Filter拦截问题 刚开始我创建了个servlet项目一直拦截不成功 首先是因为导包的问题      import javax.servlet.*; 必须是这个包才有 第一个这个Javax.se ...

  4. MongoDB中的分布式集群架构

    MongoDB 中的分布式集群架构 前言 Replica Set 副本集模式 副本集写和读的特性 Sharding 分片模式 分片的优势 MongoDB 分片的组件 分片键 chunk 是什么 分片的 ...

  5. Educational Codeforces Round 26 Problem A

    A. Text Volume time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  6. 可视化学习:CSS transform与仿射变换

    引言 在几年前,我就在一些博客中看到关于CSS中transform的分析,讲到它与线性代数中矩阵的关系,但当时由于使用transform比较少,再加上我毕竟是个数学学渣,对数学有点畏难心理,就有点看不 ...

  7. Vue3节流指令封装

    节流指令 import { ObjectDirective } from 'vue' interface ThrottleEl extends HTMLElement { throttleEvent: ...

  8. 【笔记-错误】springCloud-alibaba-feign集成sentinel的启动报错

    背景 随着Spring Cloud Alibaba 2.2.0.RELEASE的发布,终于可以使用最新的Spring Boot和Spring Cloud. 现在的环境 依赖 版本 Spring Boo ...

  9. Java单例模式的几种常见实现方式

    目录 Java单例模式的几种常见实现方式 懒汉or饿汉? 饿汉:不加锁,线程安全,用起来方便,容易产生垃圾对象 单线程下的单例模式(懒汉,线程不安全) 多线程下的单例模式(一)(懒汉,线程安全) 多线 ...

  10. 中国汽车工业协会 SDV 软件定义汽车服务 API 第三版下载

    开门见山,下载链接: https://files.cnblogs.com/files/tengzijian/SDV_API_Version3_Beta1_公众号:好记性如烂笔头.zip?t=16904 ...