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 ...
随机推荐
- Taro/JS/H5/小程序:纯前端解决小程序微信支付统一下单和调起支付
这个文章不会说具体0到1的代码流程,我会着重讲几个问题的解决 准备以下依赖 "md5": "^2.2.1", "xml-js": " ...
- Salesforce 自定义元数据类型
自定义元数据类型的优点 Salesforce中的设定都是以元数据(Metadata)存在的.在Salesforce中,用户可以新建自定义对象.自定义字段等,这些数据结构都以元数据的形式存储在系统中.当 ...
- <DFS & BFS> 130 127
130. Surrounded Regions BFS: 把所有边界上的O先换成A(标记),再深度遍历周围的点. 最后把O换成X(表示不符合要求),所有的A换回O class Solution { p ...
- 测试总结(没有rank1)
一个初三蒟蒻不可能rank1.jpg T1: 给出两个单词 (开始单词和结束单词) 以及一个词典. 找出从开始单词转换到结束单词,所需要的最短转换序列.转换的规则如下:1.每次只能改变一个字母2.转换 ...
- php-fpm指定配置文件及php相关配置命令
[root@hostname centos7 sbin]# ./php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm. ...
- mac 浏览器(chrome, safari)信任自签名证书
mac 浏览器(chrome, safari)信任自签名证书 自签名证书创建了一个 https 服务器,但是浏览器访问的时候总是不信任证书,感觉很烦,就想如果信任这个证书就不会有问题了. 方法1: 直 ...
- Python【每日一问】36
问: 基础题: 809*x=800*x+9*x+1 其中 x 代表的两位数, 8*x 的结果为两位数, 9*x 的结果为 3 位数.求 x ,及计算 809*x 的结果. 提高题: 对文件" ...
- 明解C语言 入门篇 第五章答案
练习5-1 /* 依次把1.2.3.4.5 赋值给数组的每个元素并显示(使用for语句) */ #include <stdio.h> int main(void) { int i; ]; ...
- SQL --------------- order by 排序
首先创建一个表弄点数据 order by 关键字用于排序查询 默认按照升序(asc)进行排列 降序要使用 desc排序方式:数字按照大小 英文字母和汉字按照第一个字母 从 a-z 排列语 法: ...
- ECS -------------- 更换系统
由于是在云服务器上所以更换系统比较简单 1.首先将你运行的实例停止 点击确定 2. 将停止的系统进行更换 确定 点击批量更改 更换需要的系统 点击确定 更换系统输入手机验证码. 更换好了 3.修改远程 ...