DataManageController.java 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. /**
  2. * Copyright 2019 DH
  3. * All right reserved.
  4. * 项目名称:
  5. * 创建日期:2022/8/31
  6. */
  7. package org.springblade.modules.manage.controller;
  8. import com.alibaba.excel.EasyExcel;
  9. import com.alibaba.excel.context.AnalysisContext;
  10. import com.alibaba.excel.read.listener.ReadListener;
  11. import com.alibaba.fastjson.JSON;
  12. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  13. import com.baomidou.mybatisplus.core.metadata.IPage;
  14. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  15. import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
  16. import io.swagger.annotations.Api;
  17. import io.swagger.annotations.ApiImplicitParam;
  18. import io.swagger.annotations.ApiImplicitParams;
  19. import io.swagger.annotations.ApiOperation;
  20. import lombok.AllArgsConstructor;
  21. import org.springblade.core.boot.ctrl.BladeController;
  22. import org.springblade.core.log.annotation.ApiLog;
  23. import org.springblade.core.mp.support.Condition;
  24. import org.springblade.core.mp.support.Query;
  25. import org.springblade.core.oss.model.BladeFile;
  26. import org.springblade.core.tool.api.R;
  27. import org.springblade.core.tool.utils.Func;
  28. import org.springblade.modules.baseinfo.project.service.IProjectBaseInfoService;
  29. import org.springblade.modules.baseinfo.rtu.service.IRtuBaseInfoService;
  30. import org.springblade.modules.baseinfo.stbase.service.IMvAttStBaseService;
  31. import org.springblade.modules.manage.dto.RtuImportRecordDTO;
  32. import org.springblade.modules.manage.entity.RtuImportRecordDetailEntity;
  33. import org.springblade.modules.manage.entity.RtuImportRecordEntity;
  34. import org.springblade.modules.manage.entity.RtuInfoTableDataEntity;
  35. import org.springblade.modules.manage.service.IRtuImportRecordDetailService;
  36. import org.springblade.modules.manage.service.IRtuImportRecordService;
  37. import org.springblade.modules.system.service.IDictBizService;
  38. import org.springblade.modules.manage.task.RtuImportTask;
  39. import org.springblade.modules.manage.vo.RtuImportRecordVO;
  40. import org.springblade.modules.resource.builder.oss.OssBuilder;
  41. import org.springblade.modules.system.service.IDeptService;
  42. import org.springblade.jobtask.TaskManager;
  43. import org.springframework.web.bind.annotation.*;
  44. import org.springframework.web.multipart.MultipartFile;
  45. import springfox.documentation.annotations.ApiIgnore;
  46. import javax.annotation.Resource;
  47. import java.util.*;
  48. import java.util.concurrent.FutureTask;
  49. /***
  50. * Date:2022/8/31
  51. * Title:文件所属模块(必须填写)
  52. * Description:对本文件的详细描述,原则上不能少于30字
  53. * @author dylan
  54. * @version 1.0
  55. * Remark:认为有必要的其他信息
  56. */
  57. @RestController
  58. @RequestMapping("galaxy-business/data/manage")
  59. @AllArgsConstructor
  60. @Api(value = "数据管理模块", tags = "数据管理模块")
  61. public class DataManageController extends BladeController {
  62. final IProjectBaseInfoService projectBaseInfoService;
  63. final IRtuBaseInfoService rtuBaseInfoService;
  64. final IRtuImportRecordService rtuImportRecordService;
  65. final IRtuImportRecordDetailService rtuImportRecordDetailService;
  66. final IDeptService deptService;
  67. final IMvAttStBaseService mvAttStBaseService;
  68. final IDictBizService dictBizService;
  69. @Resource
  70. private OssBuilder ossBuilder;
  71. @Resource
  72. private TaskManager taskManager;
  73. @GetMapping("/page")
  74. @ApiOperationSupport(order = 2)
  75. @ApiOperation(value = "分页")
  76. public R<IPage<RtuImportRecordVO>> list(Query query) {
  77. return R.data(rtuImportRecordService.selectPage(Condition.getPage(query)));
  78. }
  79. @GetMapping("/detail/page")
  80. @ApiOperationSupport(order = 2)
  81. @ApiOperation(value = "分页")
  82. public R<IPage<RtuImportRecordDetailEntity>> detailPage(@ApiIgnore RtuImportRecordDetailEntity entity, Query query) {
  83. LambdaQueryWrapper<RtuImportRecordDetailEntity> wrapper = Wrappers.<RtuImportRecordDetailEntity>query().lambda();
  84. wrapper.eq(RtuImportRecordDetailEntity::getIsDeleted, 0);
  85. wrapper.eq(RtuImportRecordDetailEntity::getRecordId, entity.getId());
  86. wrapper.orderByDesc(RtuImportRecordDetailEntity::getSaveType);
  87. return R.data(rtuImportRecordDetailService.page(Condition.getPage(query), wrapper));
  88. }
  89. @ApiLog("测站信息-导入")
  90. @GetMapping(value = "/import/rtu/test")
  91. @ApiOperationSupport(order = 6)
  92. @ApiOperation(value = "导入测站信息", notes = "")
  93. public R importTest() {
  94. try {
  95. String filePath = "D:\\tmp\\rtu\\xa.xlsx";
  96. // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
  97. EasyExcel.read(filePath, RtuInfoTableDataEntity.class, new ReadListener() {
  98. @Override
  99. public void invoke(Object o, AnalysisContext analysisContext) {
  100. System.out.println(JSON.toJSONString(o));
  101. }
  102. @Override
  103. public void doAfterAllAnalysed(AnalysisContext analysisContext) {
  104. }
  105. }).sheet().doRead();
  106. // int sheetIndex = 0;
  107. //
  108. // // 定义输入流
  109. // FileInputStream fis = null;
  110. // List<Map> datas = null;
  111. //
  112. // try {
  113. // // 创建输入流对象
  114. // fis = new FileInputStream(filePath);
  115. // // 创建一个easypoi使用的配置类
  116. // ImportParams params = new ImportParams();
  117. // // 设置表格坐标
  118. // params.setStartSheetIndex(sheetIndex);
  119. // // 校验Excel文件,去掉空行
  120. // params.setNeedVerify(true);
  121. // // 读取数据
  122. // datas = ExcelImportUtil.importExcel(fis, Map.class, params);
  123. // } catch (Exception e) {
  124. // e.printStackTrace();
  125. // } finally {
  126. // try {
  127. // if (fis != null) {
  128. // fis.close();
  129. // }
  130. // } catch (IOException e) {
  131. // e.printStackTrace();
  132. // }
  133. // }
  134. //
  135. // for (Map apiInfo : datas) {
  136. // System.out.println(apiInfo);
  137. // }
  138. return R.success("导入成功");
  139. } catch (Exception e) {
  140. return R.fail("导入错误 " + e.getMessage());
  141. }
  142. }
  143. @ApiLog("测站信息-导入")
  144. @ApiImplicitParams({
  145. @ApiImplicitParam(name = "remark", value = "导入说明", paramType = "query", dataType = "string"),
  146. @ApiImplicitParam(name = "saveType", value = "操作类型", paramType = "query", dataType = "int"),
  147. })
  148. @PostMapping(value = "/import/rtu")
  149. @ApiOperationSupport(order = 6)
  150. @ApiOperation(value = "导入测站信息", notes = "")
  151. public R importRtuTable(@ApiIgnore RtuImportRecordDTO rtuImportRecordDTO, MultipartFile file) {
  152. try {
  153. BladeFile bladeFile = ossBuilder.template().putFile(file);
  154. if (null == bladeFile) {
  155. return R.fail("导入失败");
  156. }
  157. RtuImportRecordEntity recordEntity = new RtuImportRecordEntity();
  158. recordEntity.setImportStatus(0L);
  159. recordEntity.setRemark(rtuImportRecordDTO.getRemark());
  160. recordEntity.setSaveType(rtuImportRecordDTO.getSaveType());
  161. recordEntity.setImportTime(Func.formatDateTime(new Date()));
  162. recordEntity.setFileName(file.getOriginalFilename());
  163. this.rtuImportRecordService.save(recordEntity);
  164. RtuImportTask task = new RtuImportTask(bladeFile, recordEntity, this.rtuBaseInfoService, this.rtuImportRecordService, this.rtuImportRecordDetailService,this.dictBizService);
  165. FutureTask<Integer> futureTask = new FutureTask<>(task);
  166. taskManager.submitTask(futureTask);
  167. return R.success("导入任务提交成功");
  168. } catch (Exception e) {
  169. e.printStackTrace();
  170. return R.fail("导入错误 " + e.getMessage());
  171. }
  172. }
  173. }