f16c7097e0d237034cbfa2ba41dbac27d90bcacb.svn-base 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. package org.jeecg.common.system.base.controller;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import com.baomidou.mybatisplus.core.metadata.IPage;
  4. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  5. import com.baomidou.mybatisplus.extension.service.IService;
  6. import lombok.extern.slf4j.Slf4j;
  7. import org.apache.commons.beanutils.PropertyUtils;
  8. import org.apache.shiro.SecurityUtils;
  9. import org.jeecg.common.api.vo.Result;
  10. import org.jeecg.common.system.query.QueryGenerator;
  11. import org.jeecg.common.system.vo.LoginUser;
  12. import org.jeecg.common.util.oConvertUtils;
  13. import org.jeecgframework.poi.excel.ExcelImportUtil;
  14. import org.jeecgframework.poi.excel.def.NormalExcelConstants;
  15. import org.jeecgframework.poi.excel.entity.ExportParams;
  16. import org.jeecgframework.poi.excel.entity.ImportParams;
  17. import org.jeecgframework.poi.excel.entity.enmus.ExcelType;
  18. import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
  19. import org.springframework.beans.factory.annotation.Autowired;
  20. import org.springframework.beans.factory.annotation.Value;
  21. import org.springframework.web.multipart.MultipartFile;
  22. import org.springframework.web.multipart.MultipartHttpServletRequest;
  23. import org.springframework.web.servlet.ModelAndView;
  24. import javax.servlet.http.HttpServletRequest;
  25. import javax.servlet.http.HttpServletResponse;
  26. import java.io.IOException;
  27. import java.util.*;
  28. import java.util.stream.Collectors;
  29. /**
  30. * @Description: Controller基类
  31. * @Author: dangzhenghui@163.com
  32. * @Date: 2019-4-21 8:13
  33. * @Version: 1.0
  34. */
  35. @Slf4j
  36. public class JeecgController<T, S extends IService<T>> {
  37. @Autowired
  38. S service;
  39. @Value("${jeecg.path.upload}")
  40. private String upLoadPath;
  41. /**
  42. * 导出excel
  43. *
  44. * @param request
  45. */
  46. protected ModelAndView exportXls(HttpServletRequest request, T object, Class<T> clazz, String title) {
  47. // Step.1 组装查询条件
  48. QueryWrapper<T> queryWrapper = QueryGenerator.initQueryWrapper(object, request.getParameterMap());
  49. LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
  50. // Step.2 获取导出数据
  51. List<T> pageList = service.list(queryWrapper);
  52. List<T> exportList = null;
  53. // 过滤选中数据
  54. String selections = request.getParameter("selections");
  55. if (oConvertUtils.isNotEmpty(selections)) {
  56. List<String> selectionList = Arrays.asList(selections.split(","));
  57. exportList = pageList.stream().filter(item -> selectionList.contains(getId(item))).collect(Collectors.toList());
  58. } else {
  59. exportList = pageList;
  60. }
  61. // Step.3 AutoPoi 导出Excel
  62. ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
  63. mv.addObject(NormalExcelConstants.FILE_NAME, title); //此处设置的filename无效 ,前端会重更新设置一下
  64. mv.addObject(NormalExcelConstants.CLASS, clazz);
  65. //update-begin--Author:liusq Date:20210126 for:图片导出报错,ImageBasePath未设置--------------------
  66. ExportParams exportParams=new ExportParams(title + "报表", "导出人:" + sysUser.getRealname(), title);
  67. exportParams.setImageBasePath(upLoadPath);
  68. //update-end--Author:liusq Date:20210126 for:图片导出报错,ImageBasePath未设置----------------------
  69. mv.addObject(NormalExcelConstants.PARAMS,exportParams);
  70. mv.addObject(NormalExcelConstants.DATA_LIST, exportList);
  71. return mv;
  72. }
  73. /**
  74. * 根据每页sheet数量导出多sheet
  75. *
  76. * @param request
  77. * @param object 实体类
  78. * @param clazz 实体类class
  79. * @param title 标题
  80. * @param exportFields 导出字段自定义
  81. * @param pageNum 每个sheet的数据条数
  82. * @param request
  83. */
  84. protected ModelAndView exportXlsSheet(HttpServletRequest request, T object, Class<T> clazz, String title,String exportFields,Integer pageNum) {
  85. // Step.1 组装查询条件
  86. QueryWrapper<T> queryWrapper = QueryGenerator.initQueryWrapper(object, request.getParameterMap());
  87. LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
  88. // Step.2 计算分页sheet数据
  89. double total = service.count();
  90. int count = (int)Math.ceil(total/pageNum);
  91. // Step.3 多sheet处理
  92. List<Map<String, Object>> listMap = new ArrayList<Map<String, Object>>();
  93. for (int i = 1; i <=count ; i++) {
  94. Page<T> page = new Page<T>(i, pageNum);
  95. IPage<T> pageList = service.page(page, queryWrapper);
  96. List<T> records = pageList.getRecords();
  97. List<T> exportList = null;
  98. // 过滤选中数据
  99. String selections = request.getParameter("selections");
  100. if (oConvertUtils.isNotEmpty(selections)) {
  101. List<String> selectionList = Arrays.asList(selections.split(","));
  102. exportList = records.stream().filter(item -> selectionList.contains(getId(item))).collect(Collectors.toList());
  103. } else {
  104. exportList = records;
  105. }
  106. Map<String, Object> map = new HashMap<String, Object>();
  107. ExportParams exportParams=new ExportParams(title + "报表", "导出人:" + sysUser.getRealname(), title+i,upLoadPath);
  108. exportParams.setType(ExcelType.XSSF);
  109. //map.put("title",exportParams);//表格Title
  110. map.put(NormalExcelConstants.PARAMS,exportParams);//表格Title
  111. map.put(NormalExcelConstants.CLASS,clazz);//表格对应实体
  112. map.put(NormalExcelConstants.DATA_LIST, exportList);//数据集合
  113. listMap.add(map);
  114. }
  115. // Step.4 AutoPoi 导出Excel
  116. ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
  117. mv.addObject(NormalExcelConstants.FILE_NAME, title); //此处设置的filename无效 ,前端会重更新设置一下
  118. mv.addObject(NormalExcelConstants.MAP_LIST, listMap);
  119. return mv;
  120. }
  121. /**
  122. * 根据权限导出excel,传入导出字段参数
  123. *
  124. * @param request
  125. */
  126. protected ModelAndView exportXls(HttpServletRequest request, T object, Class<T> clazz, String title,String exportFields) {
  127. ModelAndView mv = this.exportXls(request,object,clazz,title);
  128. mv.addObject(NormalExcelConstants.EXPORT_FIELDS,exportFields);
  129. return mv;
  130. }
  131. /**
  132. * 获取对象ID
  133. *
  134. * @return
  135. */
  136. private String getId(T item) {
  137. try {
  138. return PropertyUtils.getProperty(item, "id").toString();
  139. } catch (Exception e) {
  140. e.printStackTrace();
  141. return null;
  142. }
  143. }
  144. /**
  145. * 通过excel导入数据
  146. *
  147. * @param request
  148. * @param response
  149. * @return
  150. */
  151. protected Result<?> importExcel(HttpServletRequest request, HttpServletResponse response, Class<T> clazz) {
  152. MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
  153. Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
  154. for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
  155. MultipartFile file = entity.getValue();// 获取上传文件对象
  156. ImportParams params = new ImportParams();
  157. params.setTitleRows(2);
  158. params.setHeadRows(1);
  159. params.setNeedSave(true);
  160. try {
  161. List<T> list = ExcelImportUtil.importExcel(file.getInputStream(), clazz, params);
  162. //update-begin-author:taoyan date:20190528 for:批量插入数据
  163. long start = System.currentTimeMillis();
  164. service.saveBatch(list);
  165. //400条 saveBatch消耗时间1592毫秒 循环插入消耗时间1947毫秒
  166. //1200条 saveBatch消耗时间3687毫秒 循环插入消耗时间5212毫秒
  167. log.info("消耗时间" + (System.currentTimeMillis() - start) + "毫秒");
  168. //update-end-author:taoyan date:20190528 for:批量插入数据
  169. return Result.ok("文件导入成功!数据行数:" + list.size());
  170. } catch (Exception e) {
  171. log.error(e.getMessage(), e);
  172. return Result.error("文件导入失败:" + e.getMessage());
  173. } finally {
  174. try {
  175. file.getInputStream().close();
  176. } catch (IOException e) {
  177. e.printStackTrace();
  178. }
  179. }
  180. }
  181. return Result.error("文件导入失败!");
  182. }
  183. }