From 8ff6842edf6229bb40344eafc4fe084fb09c7d24 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期三, 26 二月 2025 14:02:34 +0800
Subject: [PATCH] Merge branch 'xizang-changyun' of https://gitee.com/xiaochen991015/xizang

---
 ruoyi-system/src/main/java/com/ruoyi/system/importExcel/TBankFlowImportExcel.java        |   51 ++++++++++
 ruoyi-system/src/main/java/com/ruoyi/system/service/TBankFlowService.java                |    4 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TBankFlowController.java          |   74 ++++++++++++++
 ruoyi-system/pom.xml                                                                     |    6 +
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java       |   82 ++++++++++++++++
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFlowManagementServiceImpl.java |    1 
 ruoyi-system/src/main/java/com/ruoyi/system/service/TFlowManagementService.java          |    1 
 pom.xml                                                                                  |   30 +++---
 8 files changed, 231 insertions(+), 18 deletions(-)

diff --git a/pom.xml b/pom.xml
index 0bcee27..fbf1dea 100644
--- a/pom.xml
+++ b/pom.xml
@@ -87,24 +87,24 @@
             </dependency>
 
             <!-- excel工具 -->
-<!--            <dependency>-->
-<!--                <groupId>org.apache.poi</groupId>-->
-<!--                <artifactId>poi-ooxml</artifactId>-->
-<!--                <version>${poi.version}</version>-->
-<!--            </dependency>-->
+           <dependency>
+               <groupId>org.apache.poi</groupId>
+               <artifactId>poi-ooxml</artifactId>
+               <version>${poi.version}</version>
+           </dependency>
 
 
-<!--            <dependency>-->
-<!--                <groupId>org.apache.poi</groupId>-->
-<!--                <artifactId>poi</artifactId>-->
-<!--                <version>${poi.version}</version>-->
-<!--            </dependency>-->
+           <dependency>
+               <groupId>org.apache.poi</groupId>
+               <artifactId>poi</artifactId>
+               <version>${poi.version}</version>
+           </dependency>
 
-<!--            <dependency>-->
-<!--                <groupId>org.apache.poi</groupId>-->
-<!--                <artifactId>poi-ooxml-schemas</artifactId>-->
-<!--                <version>${poi.version}</version>-->
-<!--            </dependency>-->
+           <dependency>
+               <groupId>org.apache.poi</groupId>
+               <artifactId>poi-ooxml-schemas</artifactId>
+               <version>${poi.version}</version>
+           </dependency>
 
             <!-- velocity代码生成使用模板 -->
             <dependency>
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..e6849a9 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,8 +1,13 @@
 package com.ruoyi.web.controller.api;
 
 
+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.importExcel.TBankFlowImportExcel;
 import com.ruoyi.system.model.TBankFlow;
 import com.ruoyi.system.query.TBankFlowQuery;
 import com.ruoyi.system.service.TBankFlowService;
@@ -14,6 +19,15 @@
 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.multipart.MultipartFile;
+
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Vector;
+import java.util.concurrent.atomic.AtomicInteger;
 
 /**
  * <p>
@@ -28,6 +42,7 @@
 public class TBankFlowController {
     @Autowired
     private TBankFlowService flowService;
+
     /**
      * 获取流水列表
      */
@@ -40,8 +55,65 @@
 
     @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();
+
+
+            // 导出导入结果
+            HttpServletResponse response = WebUtils.response();
+            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);
+            }
+
+        } catch (Exception e) {
+            e.printStackTrace();
+            System.err.println("银行流水返回结果导出失败");
+        }
+    }
 }
 
+
+
diff --git a/ruoyi-system/pom.xml b/ruoyi-system/pom.xml
index 80a2359..da794d7 100644
--- a/ruoyi-system/pom.xml
+++ b/ruoyi-system/pom.xml
@@ -51,6 +51,12 @@
             <artifactId>mybatis-plus-boot-starter</artifactId>
             <version>3.5.2</version>
         </dependency>
+        <!--集成EasyExcel -->
+        <dependency>
+            <groupId>com.alibaba</groupId>
+            <artifactId>easyexcel</artifactId>
+            <version>2.1.6</version>
+        </dependency>
 
 
 <!--        <dependency>-->
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/importExcel/TBankFlowImportExcel.java b/ruoyi-system/src/main/java/com/ruoyi/system/importExcel/TBankFlowImportExcel.java
new file mode 100644
index 0000000..c61ae4d
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/importExcel/TBankFlowImportExcel.java
@@ -0,0 +1,51 @@
+package com.ruoyi.system.importExcel;
+
+import com.alibaba.excel.annotation.ExcelProperty;
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+import org.apache.commons.lang3.StringUtils;
+
+import java.io.Serializable;
+import java.math.BigDecimal;
+
+/**
+ * @author 64502
+ */
+@Data
+@ApiModel(value="银行流水导入Excel")
+public class TBankFlowImportExcel implements Serializable {
+
+
+    @ExcelProperty("银行流水号")
+    private String bankSerialNumber;
+
+    @ExcelProperty("流水金额")
+    private BigDecimal flowMoney;
+
+    @ExcelProperty("支付时间")
+    private String payTime;
+
+    @ExcelProperty("付款人")
+    private String payer;
+
+    @ExcelProperty("导入结果")
+    private String result;
+
+    public boolean validate() {
+        if (StringUtils.isEmpty(bankSerialNumber)){
+            result = "银行流水号不能为空";
+            return false;
+        }
+        if (StringUtils.isEmpty(payTime)){
+            result = "支付时间不能为空";
+            return false;
+        }
+        if (flowMoney == null){
+            result = "流水金额不能为空";
+            return false;
+        }
+        return true;
+    }
+
+
+}
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/TBankFlowService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/TBankFlowService.java
index 46234e1..711ee30 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/TBankFlowService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/TBankFlowService.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.extension.service.IService;
 import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.system.importExcel.TBankFlowImportExcel;
 import com.ruoyi.system.model.TBankFlow;
 import com.ruoyi.system.query.TBankFlowQuery;
 import com.ruoyi.system.vo.TBankFlowStatisticsVo;
@@ -21,8 +22,9 @@
     PageInfo<TBankFlow> pageList(TBankFlowQuery query);
     List<TBankFlow> makeQuery(TBankFlowQuery query);
     TBankFlowStatisticsVo getPaymentStats( TBankFlowQuery query);
-
     List<TBankFlow> searchByBankSerialNumber(String bankSerialNumber);
 
+    void saveImportBatch(List<TBankFlowImportExcel> list, List<TBankFlowImportExcel> failList);
+    TBankFlow findUniq(String bankSerialNumber);
 
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/TFlowManagementService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/TFlowManagementService.java
index 0d95c6e..bf137ff 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/TFlowManagementService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/TFlowManagementService.java
@@ -22,5 +22,4 @@
     TFlowManagementStatisticsVo getPaymentStats(TFlowManagementQuery req);
 
 
-
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java
index 89e5fec..fc5e23e 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java
@@ -1,16 +1,30 @@
 package com.ruoyi.system.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.Query;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.system.importExcel.TBankFlowImportExcel;
 import com.ruoyi.system.mapper.TBankFlowMapper;
 import com.ruoyi.system.model.TBankFlow;
+import com.ruoyi.system.model.TFlowManagement;
 import com.ruoyi.system.query.TBankFlowQuery;
+import com.ruoyi.system.query.TFlowManagementQuery;
 import com.ruoyi.system.service.TBankFlowService;
+import com.ruoyi.system.service.TFlowManagementService;
 import com.ruoyi.system.vo.TBankFlowStatisticsVo;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.time.LocalDate;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.time.format.DateTimeParseException;
 import java.util.List;
 
 /**
@@ -23,6 +37,8 @@
  */
 @Service
 public class TBankFlowServiceImpl extends ServiceImpl<TBankFlowMapper, TBankFlow> implements TBankFlowService {
+    @Autowired
+    TFlowManagementService flowManagementService;
     @Override
     public PageInfo<TBankFlow> pageList(TBankFlowQuery query) {
         PageInfo<TBankFlow> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
@@ -61,4 +77,70 @@
         queryWrapper.like(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber);
         return this.baseMapper.selectList(queryWrapper);
     }
+
+    @Override
+    public void saveImportBatch(List<TBankFlowImportExcel> list, List<TBankFlowImportExcel> failList) {
+        for (TBankFlowImportExcel row : list) {
+            try {
+                TBankFlow preexist = findUniq(row.getBankSerialNumber());
+                if (preexist != null){
+                    row.setResult("流水号已存在"+row.getBankSerialNumber());
+                    failList.add(row);
+                    continue;
+                }
+                TBankFlow flow = new TBankFlow();
+                BeanUtils.copyProperties(row,flow);
+                try {
+                    LocalDateTime parse = LocalDateTime.parse(row.getPayTime(), DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+                    flow.setPayTime(parse);
+                }catch (DateTimeParseException e){
+                    row.setResult("支付时间格式不正确"+row.getPayTime());
+                    failList.add(row);
+                    continue;
+                }
+                TFlowManagementQuery query = new TFlowManagementQuery();
+                query.setBankSerialNumber(row.getBankSerialNumber());
+                List<TFlowManagement> list1 = flowManagementService.makeQuery(query);
+                for (TFlowManagement tFlowManagement : list1) {
+                    // 如果相同流水号金额相同 :抵扣金额为流水金额,剩余金额为0,状态为正常
+                    if (row.getFlowMoney().compareTo(tFlowManagement.getFlowMoney()) == 0){
+                        flow.setDeductionMoney(tFlowManagement.getFlowMoney());
+                        flow.setRemainingMoney(BigDecimal.ZERO);
+                        flow.setFlowStatus(1);
+                        this.baseMapper.insert(flow);
+                        break;
+                    }else {
+                        // 流水号相同,金额不同:已抵扣金额为系统流水金额,剩余金额 = 银行流水金额-系统流水金额,状态为异常
+                        flow.setDeductionMoney(tFlowManagement.getFlowMoney());
+                        flow.setRemainingMoney(row.getFlowMoney().divide(tFlowManagement.getFlowMoney(),2, RoundingMode.HALF_DOWN));
+                        flow.setFlowStatus(2);
+                        this.baseMapper.insert(flow);
+                        break;
+                    }
+                }
+                // 系统流水查找不到:抵扣金额为0,剩余金额为流水金额,状态为异常
+                flow.setDeductionMoney(BigDecimal.ZERO);
+                flow.setRemainingMoney(row.getFlowMoney());
+                flow.setFlowStatus(2);
+                this.baseMapper.insert(flow);
+            }catch (Exception e){
+                log.error("导入银行流水信息异常",e);
+                row.setResult("导入异常:"+e.getMessage());
+                failList.add(row);
+            }
+        }
+    }
+
+    /**
+     * 根据流水号查找唯一流水
+     * @param bankSerialNumber
+     * @return
+     */
+
+    @Override
+    public TBankFlow findUniq(String bankSerialNumber) {
+        LambdaQueryWrapper<TBankFlow> queryWrapper = new LambdaQueryWrapper<>();
+        queryWrapper.eq(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber);
+        return this.baseMapper.selectOne(queryWrapper);
+    }
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFlowManagementServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFlowManagementServiceImpl.java
index f5fe8b4..98ef5a0 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFlowManagementServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFlowManagementServiceImpl.java
@@ -50,4 +50,5 @@
     public TFlowManagementStatisticsVo getPaymentStats(TFlowManagementQuery query) {
         return this.baseMapper.getPaymentStats(query);
     }
+
 }

--
Gitblit v1.7.1