spring boot缓存excel临时文件后再操作
1. 引入poi的两个依赖
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.15</version>
</dependency>
2. controller层
package com.cdqd.app.controllers;
import com.cdqd.app.common.JsonRet;
import com.cdqd.app.exception.BizException;
import com.cdqd.app.service.TranslateService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.MultipartRequest;
import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Objects;
/**
* @description:
* @author: Rosa
* @create: 2018-12-24 10:06
**/
@RestController
@RequestMapping("translate")
public class TranslateController {
@Autowired
private TranslateService translateService;
@PostMapping("source/name")
public JsonRet translateSourceName(HttpServletRequest request) throws Exception{
MultipartRequest multipartHttpServletRequest = (MultipartRequest) request;
MultipartFile multipartFile = multipartHttpServletRequest.getFile("file");
//如果为空,抛出异常,此处为自定义异常,如有需要请改写
if (Objects.requireNonNull(multipartFile).isEmpty()){
throw new BizException(4001);
}
//存储临时文件
String fileName = multipartFile.getOriginalFilename();
String prefix = fileName.substring(Objects.requireNonNull(fileName).lastIndexOf("."));
File file = File.createTempFile(System.currentTimeMillis() + "", prefix);
multipartFile.transferTo(file);
//调用service对流进行具体操作
translateService.translateSourceDatabase(new FileInputStream(file));
return JsonRet.buildRet(0);//
}
}
3. service层(给自己回忆用的,针对性强,读者没有必要往下看了)
接口: TranslateService.java
package com.cdqd.app.service;
import java.io.InputStream;
public interface TranslateService {
void translateSourceDatabase(InputStream inputStream);
}
实现文件: TranslateServiceImpl.java
package com.cdqd.app.service.impl;
import com.cdqd.app.common.StringUtil;
import com.cdqd.app.entity.DatabaseEntity;
import com.cdqd.app.entity.TableEntity;
import com.cdqd.app.exception.BizException;
import com.cdqd.app.mapper.ColumnMapper;
import com.cdqd.app.mapper.DatabaseMapper;
import com.cdqd.app.mapper.TableMapper;
import com.cdqd.app.model.Column;
import com.cdqd.app.model.Database;
import com.cdqd.app.model.Table;
import com.cdqd.app.service.TableService;
import com.cdqd.app.service.TranslateService;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @description:
* @author: Rosa
* @create: 2018-12-24 10:04
**/
@Service
public class TranslateServiceImpl implements TranslateService {
@Autowired
private DatabaseMapper databaseMapper;
@Autowired
private TableMapper tableMapper;
@Autowired
private ColumnMapper columnMapper;
@Autowired
private TableService tableService;
@Override
public void translateSourceDatabase(InputStream inputStream) {
Map<String, Map<String, TableEntity>> databaseMap = getTransMap(inputStream);
//遍历所有库
if (databaseMap != null) {
for (String databaseEnName : databaseMap.keySet()) {
Database database = new Database();
database.setDatabaseEnName(databaseEnName);
//如果库存在则开始遍历表
if (databaseMapper.selectOne(database) != null) {
Integer databaseId = databaseMapper.selectOne(database).getDatabaseId();
//MapKey("tableEnName")
Map<String, TableEntity> dbTableMap = tableService.getTableEntityMap(databaseId);
//<表英文名, 表实体>
Map<String, TableEntity> excelTableMap = databaseMap.get(databaseEnName);
//遍历数据库map的表实体
for (String dbTableEnName : dbTableMap.keySet()) {
TableEntity dbTableEntity = dbTableMap.get(dbTableEnName);
//如果excel数据中有这边的表
if (excelTableMap.containsKey(dbTableEnName)) {
TableEntity excelTableEntity = excelTableMap.get(dbTableEnName);
//源表表名翻译
if (!StringUtil.isEmpty(excelTableEntity.getTableCnName())) {
Table table = new Table();
table.setTableId(dbTableEntity.getTableId());
table.setTableCnName(excelTableEntity.getTableCnName());
tableMapper.updateByPrimaryKeySelective(table);
}
//如果列不为空的话
if (dbTableEntity.getColumnList() != null && excelTableEntity.getColumnMap() != null) {
//<列英文名, 列实体>
Map<String, Column> excelColumnMap = excelTableEntity.getColumnMap();
for (Column dbColumn : dbTableEntity.getColumnList()) {
if (excelColumnMap.containsKey(dbColumn.getColumnEnName())) {
String columnCnName = excelColumnMap.get(dbColumn.getColumnEnName()).getColumnCnName();
if (!StringUtil.isEmpty(columnCnName)) {
//如果列中文名不为空,翻译列名
Column column = new Column();
column.setColumnId(dbColumn.getColumnId());
column.setColumnCnName(columnCnName);
columnMapper.updateByPrimaryKeySelective(column);
}
}
}
}
}
}
}
}
}
// return TRANS_MAP;
}
private Map<String, Map<String, TableEntity>> getTransMap(InputStream inputStream) {
Map<String, Map<String, TableEntity>> databaseMap = new HashMap<>();
try {
XSSFWorkbook workbook = new XSSFWorkbook(inputStream);
XSSFSheet sheet = workbook.getSheetAt(0);
for (int row = 1; row < sheet.getLastRowNum(); row++) {
XSSFRow xssfRow = sheet.getRow(row);
if (xssfRow.getCell(0) == null) {
continue;
}
String databaseName = String.valueOf(xssfRow.getCell(0));
String tableEnName = String.valueOf(xssfRow.getCell(1));
String tableCnName = String.valueOf(xssfRow.getCell(2));
String columnEnName = String.valueOf(xssfRow.getCell(3));
String columnCnName = String.valueOf(xssfRow.getCell(4));
Column column = new Column();
column.setColumnEnName(columnEnName);
column.setColumnCnName(columnCnName);
if (tableEnName == null) {
continue;
}
if (databaseMap.containsKey(databaseName)) {
//<表英文名, 表实体>
Map<String, TableEntity> excelTableMap = databaseMap.get(databaseName);
//如果表存在,获取那个表实体
if (excelTableMap.containsKey(tableEnName)) {
TableEntity excelTableEntity = excelTableMap.get(tableEnName);
if (columnEnName != null && !columnEnName.equals("")) {
if (excelTableEntity.getColumnMap() != null) {
Map<String, Column> columnMap = excelTableEntity.getColumnMap();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
} else {
Map<String, Column> columnMap = new HashMap<>();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
}
}
excelTableMap.put(tableEnName, excelTableEntity);
} else {
//表不存在时插入表
TableEntity excelTableEntity = new TableEntity();
excelTableEntity.setTableEnName(tableEnName);
excelTableEntity.setTableCnName(tableCnName);
if (columnEnName != null && !columnEnName.equals("")) {
Map<String, Column> columnMap = new HashMap<>();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
}
excelTableMap.put(tableEnName, excelTableEntity);
}
} else {
Map<String, TableEntity> excelTableMap = new HashMap<>();
TableEntity excelTableEntity = new TableEntity();
excelTableEntity.setTableEnName(tableEnName);
excelTableEntity.setTableCnName(tableCnName);
if (columnEnName != null && !columnEnName.equals("")) {
Map<String, Column> columnMap = new HashMap<>();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
}
excelTableMap.put(tableEnName, excelTableEntity);
databaseMap.put(databaseName, excelTableMap);
}
}
return databaseMap;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}
spring boot缓存excel临时文件后再操作的更多相关文章
- Spring Boot项目指定启动后执行的操作
Spring Boot项目指定启动后执行的操作: (1)实现CommandLineRunner 接口 (2)重写run方法 (3)声明执行顺序@Order(1),数值越小,优先级越高 (4)如果需要注 ...
- Spring boot缓存初体验
spring boot缓存初体验 1.项目搭建 使用MySQL作为数据库,spring boot集成mybatis来操作数据库,所以在使用springboot的cache组件时,需要先搭建一个简单的s ...
- 3步轻松搞定Spring Boot缓存
作者:谭朝红 前言 本次内容主要介绍基于Ehcache 3.0来快速实现Spring Boot应用程序的数据缓存功能.在Spring Boot应用程序中,我们可以通过Spring Caching来快速 ...
- 如何解决spring boot 项目导入依赖后代码报错问题
如何解决spring boot 项目导入依赖后代码报错问题 2020-08-15 14:17:18 代码截图如图所示(由于本人问题已经解决,没来得及截图,所以在网上找了一张图片)
- Spring boot配置多个Redis数据源操作实例
原文:https://www.jianshu.com/p/c79b65b253fa Spring boot配置多个Redis数据源操作实例 在SpringBoot是项目中整合了两个Redis的操作实例 ...
- Spring Boot 导出Excel表格
Spring Boot 导出Excel表格 添加支持 <!--添加导入/出表格依赖--> <dependency> <groupId>org.apache.poi& ...
- Spring Boot缓存Ehcache
Spring Boot 整合 Ehcache 修改 pom 文件 <!-- Spring Boot 缓存支持启动器 --> <dependency> <groupId ...
- spring boot, 容器启动后执行某操作
常有在spring容器启动后执行某些操作的需求,现做了一个demo的实现,做一下记录,也希望可以给需要的同学提供参考. 1.spring启动后,以新线程执行后续需要的操作,所以执行类实现Runnabl ...
- Spring boot 配置 Tomcat 临时文件缓存目录
1. 问题现象 spring boot 项目中,Tomcat 接收到 content-type 为 multipart/form-data 的请求时,需要将接收的文件缓存到临时目录(默认下载 /tmp ...
随机推荐
- Netty线程模型(五)
Netty支持单线程.主线程模型.主从多线程模型. 我们在创建线程组的时候,如果不传递参数,则默认构建的线程组线程是CPU核心数量. 一.单线程模型 在ServerBootstrap调用方法group ...
- webapi基于单请求封装多请求的设计【转】
怎么说,单请求封装多请求,这句话确实有点绕了,但还是要看清楚,想明白这到底是怎么一回事,单请求即一次请求(get,post,put,delete),封闭多请求,即在客户端发送的一个请求中可能包含多个子 ...
- 配置好运行后Error creating context 'spring.root': Could not load type from string value
在Webconfig文件的当前项目下引用相关项目
- java 深入理解jvm内存模型 jvm学习笔记
jvm内存模型 这是java堆和方法区内存模型 参考:https://www.cnblogs.com/honey01/p/9475726.html Java 中的堆也是 GC 收集垃圾的主要区域.GC ...
- (转)yum只下载不安装软件包
方法一:使用yum的downloadonly插件 步骤: (1) 先安装downloadonly插件 yum install yum-plugin-downloadonly (2)使用–downlo ...
- Unity调用windows系统dialog 选择文件夹
#region 调用windows系统dialog 选择文件夹 [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Auto)] public ...
- js 实现 promise
本文仅用于个人技术记录,如误导他人,概不负责. 本文有参考其他文章,不过地址忘了~~~. ======================================================= ...
- ROS消息vs服务
1.ROS包消息/服务模式与要点 从功能上看,ROS包是信息交互和处理的基本单元.根据信息的交互和处理方式,ROS包有以下两大类: 消息发布者与订阅者 服务器与客户端 对于消息模式的包,信息的提供者主 ...
- java中 Math和StrictMath
今天无意中看到java api中有StrictMath 这个工具类,发现它部分调用实现是用了Math中的实现.Math 这个类API 1.0版本就有了,StrictMath API是1.3版本才出来的 ...
- Sitecore 营销分类
分类法是一种分层结构,可用于识别和组织信息.在Sitecore体验平台中,您可以使用分类法对营销活动进行分类,例如广告,目标和活动.您可以在市场营销控制面板中将分类标签应用于这些项目. 营销分类的四种 ...