From 75efe9739dd7600882365903bd1859b0ee7fb7ad Mon Sep 17 00:00:00 2001 From: zhangmei <645025773@qq.com> Date: 星期五, 21 二月 2025 14:01:07 +0800 Subject: [PATCH] 流水导入 --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TBankFlowController.java | 116 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 115 insertions(+), 1 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TBankFlowController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TBankFlowController.java index 9c5cdd4..fff605c 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TBankFlowController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TBankFlowController.java @@ -1,19 +1,41 @@ package com.ruoyi.web.controller.api; +import cn.afterturn.easypoi.excel.ExcelExportUtil; +import cn.afterturn.easypoi.excel.entity.ExportParams; +import com.alibaba.excel.EasyExcel; +import com.alibaba.excel.context.AnalysisContext; +import com.alibaba.excel.event.AnalysisEventListener; import com.ruoyi.common.basic.PageInfo; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.utils.WebUtils; +import com.ruoyi.system.export.ContractExport; +import com.ruoyi.system.importExcel.TBankFlowImportExcel; import com.ruoyi.system.model.TBankFlow; import com.ruoyi.system.query.TBankFlowQuery; import com.ruoyi.system.service.TBankFlowService; import com.ruoyi.system.vo.TBankFlowStatisticsVo; import io.swagger.annotations.ApiOperation; +import org.apache.poi.ss.usermodel.Workbook; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.context.request.RequestContextHolder; +import org.springframework.web.context.request.ServletRequestAttributes; +import org.springframework.web.multipart.MultipartFile; + +import javax.servlet.ServletOutputStream; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.io.InputStream; +import java.net.URLEncoder; +import java.util.ArrayList; +import java.util.List; +import java.util.Vector; +import java.util.concurrent.atomic.AtomicInteger; /** * <p> @@ -28,6 +50,7 @@ public class TBankFlowController { @Autowired private TBankFlowService flowService; + /** * 获取流水列表 */ @@ -40,8 +63,99 @@ @ApiOperation(value = "根据支付方式统计流水金额") @PostMapping("/getPaymentStats") - public R<TBankFlowStatisticsVo> getPaymentStats(@RequestBody TBankFlowQuery query){ + public R<TBankFlowStatisticsVo> getPaymentStats(@RequestBody TBankFlowQuery query) { return R.ok(flowService.getPaymentStats(query)); } + + @PostMapping("importBankFlow") + public void importElectronic(@RequestBody MultipartFile file) { + try ( + InputStream is = file.getInputStream(); + ) { + List<TBankFlowImportExcel> failList = new Vector<>(); + EasyExcel.read(is, TBankFlowImportExcel.class, new AnalysisEventListener<TBankFlowImportExcel>() { + private final List<TBankFlowImportExcel> list = new ArrayList<>(); + final AtomicInteger all = new AtomicInteger(); + + @Override + public void invoke(TBankFlowImportExcel data, AnalysisContext context) { + all.addAndGet(1); + boolean isok = data.validate(); + if (!isok) { + failList.add(data); + return; + } + list.add(data); + int size = list.size(); + if (size >= 100) { + flowService.saveImportBatch(list, failList); + list.clear(); + } + } + + @Override + public void doAfterAllAnalysed(AnalysisContext context) { + int size = list.size(); + if (size > 0) { + flowService.saveImportBatch(list, failList); + } + } + }).sheet().doRead(); + // 导出导入结果 + // ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); + // HttpServletResponse response = servletRequestAttributes.getResponse(); + // response.setContentType("application/vnd.ms-excel;charset=utf-8"); + // response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); + // if (failList.size()>0) { + // EasyExcel.write(response.getOutputStream(), TBankFlowImportExcel.class).sheet("Sheet1").doWrite(failList); + // } else { + // TBankFlowImportExcel result = new TBankFlowImportExcel(); + // result.setResult("全部成功"); + // failList.add(result); + // EasyExcel.write(response.getOutputStream(), TBankFlowImportExcel.class).sheet("Sheet1").doWrite(failList); + // } + + + if (failList.size()==0){ + TBankFlowImportExcel result = new TBankFlowImportExcel(); + result.setResult("全部成功"); + failList.add(result); + } + Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), TBankFlowImportExcel.class, failList); + HttpServletResponse response = WebUtils.response(); + response.setContentType("application/vnd.ms-excel"); + response.setCharacterEncoding("utf-8"); + ServletOutputStream outputStream = null; + try { + String fileName = URLEncoder.encode("银行流水返回结果.xls", "utf-8"); + response.setHeader("Content-Disposition", "attachment;filename=" + fileName); + response.setContentType("application/vnd.ms-excel;charset=UTF-8"); + response.setHeader("Pragma", "no-cache"); + response.setHeader("Cache-Control", "no-cache"); + outputStream = response.getOutputStream(); + workbook.write(outputStream); + } catch (IOException e) { + e.printStackTrace(); + System.err.println("银行流水返回结果导出失败"); + } finally { + try { + outputStream.close(); + } catch (IOException e) { + e.printStackTrace(); + } + } + + + + + + + } catch (Exception e) { + e.printStackTrace(); + System.err.println("银行流水返回结果导出失败"); + } + } } + + -- Gitblit v1.7.1