From 03c6572c7918beaa20365e69c9694a11f0d9948a Mon Sep 17 00:00:00 2001 From: hjl <1657978663@qq.com> Date: 星期一, 01 七月 2024 10:13:26 +0800 Subject: [PATCH] feat: 代码初始化 --- ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/WithdrawServiceImpl.java | 174 ++++++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 150 insertions(+), 24 deletions(-) diff --git a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/WithdrawServiceImpl.java b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/WithdrawServiceImpl.java index 6081191..799c2d5 100644 --- a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/WithdrawServiceImpl.java +++ b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/WithdrawServiceImpl.java @@ -4,20 +4,29 @@ import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.write.builder.ExcelWriterBuilder; import com.alibaba.excel.write.metadata.WriteSheet; +import com.alibaba.fastjson2.JSONObject; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.admin.entity.Order; +import com.ruoyi.admin.entity.User; import com.ruoyi.admin.entity.Withdraw; import com.ruoyi.admin.entity.WithdrawalSetting; import com.ruoyi.admin.mapper.WithdrawMapper; +import com.ruoyi.admin.request.WithdrawExportRequest; import com.ruoyi.admin.service.WithdrawService; import com.ruoyi.admin.service.WithdrawalSettingService; -import com.ruoyi.admin.vo.UserWithdrawRecordRequestVO; +import com.ruoyi.admin.utils.vx.HttpUtil; import com.ruoyi.admin.vo.UserWithdrawRecordVO; import com.ruoyi.common.core.constant.Constants; +import com.ruoyi.common.core.constant.WechatConstants; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.exception.GlobalException; +import com.ruoyi.common.core.utils.SnowflakeIdWorker; +import com.ruoyi.common.core.utils.StringUtils; import org.apache.commons.codec.CharEncoding; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.core.io.ClassPathResource; import org.springframework.stereotype.Service; import javax.annotation.Resource; @@ -27,8 +36,7 @@ import java.io.UnsupportedEncodingException; import java.math.BigDecimal; import java.net.URLEncoder; -import java.util.Arrays; -import java.util.List; +import java.util.*; import java.util.stream.Collectors; /** @@ -45,21 +53,64 @@ @Resource private WithdrawalSettingService withdrawalSettingService; + /** + * 雪花算法类 + */ + private static final SnowflakeIdWorker SNOW_FLAKE_ID_WORKER = new SnowflakeIdWorker(5, 5); + + /** + * 小程序id + */ + @Value("wx.appid") + private String appId; + /** + * 转账名称 + */ + @Value("wx.batchName") + private String batchName; + /** + * 商户号 + */ + @Value("wx.mchId") + private String mchId; + /** + * 支付证书序列号 + */ + @Value("wx.wechatPayserialNo") + private String wechatPayserialNo; + /** + * 转账备注 + */ + @Value("wx.transferRemark") + private String transferRemark; + @Override - public R<String> excelExport(List<String> ids, HttpServletResponse response) { + public R<String> excelExport(WithdrawExportRequest exportRequest, HttpServletResponse response) { try { response.setCharacterEncoding(Constants.UTF8); response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); response.setHeader("Access-Control-Expose-Headers", "Content-disposition"); - response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(Constants.EXCEL_WITHDRAWAL_FILE_NAME, CharEncoding.UTF_8) + ".xlsx"); + response.setHeader("Content-Disposition", "attachment;filename=" + + URLEncoder.encode(Constants.EXCEL_WITHDRAWAL_FILE_NAME, CharEncoding.UTF_8) + ".xlsx"); } catch (UnsupportedEncodingException e) { return R.fail("excel导出失败!"); } try { - List<Withdraw> list = lambdaQuery().in(Withdraw::getId, ids).eq(Withdraw::getIsDelete, 0).list(); + String nickname = exportRequest.getNickname(); + String userPhone = exportRequest.getUserPhone(); + String applyForTime = exportRequest.getApplyForTime(); + Integer state = exportRequest.getState(); + List<String> ids = exportRequest.getIdList(); + List<UserWithdrawRecordVO> list; + if (null != ids && !ids.isEmpty()) { + list = baseMapper.exportByIdList(ids); + } else { + list = baseMapper.exportList(nickname, userPhone, applyForTime, state); + } // excel模板封装 ExcelWriterBuilder excelWriterBuilder = EasyExcelFactory.write(response.getOutputStream()); - InputStream stream = Thread.currentThread().getContextClassLoader().getResourceAsStream("template/" + Constants.EXCEL_WITHDRAWAL_FILE_NAME + ".xlsx"); + InputStream stream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("template/" + Constants.EXCEL_WITHDRAWAL_FILE_NAME + ".xlsx"); // 自动释放资源 try (ExcelWriter excelWriter = excelWriterBuilder.withTemplate(stream).build()) { WriteSheet writeSheet = EasyExcelFactory.writerSheet().build(); @@ -75,32 +126,23 @@ } @Override - public BigDecimal withdrawalTotalMoney(List<String> cityIdList) { - return baseMapper.withdrawalTotalMoney(cityIdList); + public BigDecimal withdrawalTotalMoney(List<String> cityList) { + return baseMapper.withdrawalTotalMoney(cityList); } @Override - public BigDecimal withdrawalTotalMoneyByYear(List<String> cityIdList) { - return baseMapper.withdrawalTotalMoneyByYear(cityIdList); + public BigDecimal withdrawalTotalMoneyByYear(List<String> cityList) { + return baseMapper.withdrawalTotalMoneyByYear(cityList); } @Override - public BigDecimal withdrawalTotalMoneyByMonth(List<String> cityIdList) { - return baseMapper.withdrawalTotalMoneyByMonth(cityIdList); + public BigDecimal withdrawalTotalMoneyByMonth(List<String> cityList) { + return baseMapper.withdrawalTotalMoneyByMonth(cityList); } @Override - public UserWithdrawRecordRequestVO withdrawList(Integer userId, Page<UserWithdrawRecordVO> page) { - IPage<UserWithdrawRecordVO> record = baseMapper.withdrawList(userId, page); - // 全局审核设置 - WithdrawalSetting setting = withdrawalSettingService.lambdaQuery().one(); - Integer enableProcess; - if (null == setting) { - enableProcess = 0; - } else { - enableProcess = setting.getEnableProcess(); - } - return new UserWithdrawRecordRequestVO(record, enableProcess); + public IPage<UserWithdrawRecordVO> withdrawList(Integer userId, Page<UserWithdrawRecordVO> page) { + return baseMapper.withdrawList(userId, page); } @Override @@ -117,4 +159,88 @@ public WithdrawalSetting withdrawProcess() { return withdrawalSettingService.lambdaQuery().one(); } + + @Override + public IPage<UserWithdrawRecordVO> withdrawPage(String nickname, String userPhone, String applyForTime, Integer state, Page<UserWithdrawRecordVO> page) { + return baseMapper.withdrawPage(nickname, userPhone, applyForTime, state, page); + } + + @Override + public Boolean confirmWithdraw(User user, Order order) { + // 校验提现 + List<Withdraw> list = this.lambdaQuery().eq(Withdraw::getUserId, user.getId()) + .eq(Withdraw::getOrderId, order).list(); + List<Integer> stateList = list.stream().map(Withdraw::getState).collect(Collectors.toList()); + if (stateList.contains(Constants.ZERO)) { + throw new GlobalException("当前订单已提交提现申请,请等待审核!"); + } else if (stateList.contains(Constants.ONE)) { + throw new GlobalException("当前订单已提现通过!"); + } + return weChatPay(order.getOrderMoney(), user.getOpenId()); + } + + private boolean weChatPay(BigDecimal orderMoney, String openId) { + if (StringUtils.isBlank(openId)) { + return false; + } + Map<String, Object> postMap = new HashMap<>(8); + // 小程序 id + postMap.put(WechatConstants.APP_ID, appId); + postMap.put(WechatConstants.OUT_BATCH_NO, String.valueOf(UUID.randomUUID()).replaceAll("-", "")); + // 该笔批量转账的名称 + postMap.put(WechatConstants.BATCH_NAME, batchName); + // 转账说明,UTF8编码,最多允许32个字符 + postMap.put(WechatConstants.BATCH_REMARK, batchName); + // 转账金额单位为“分”。 总金额 + postMap.put(WechatConstants.TOTAL_AMOUNT, orderMoney.multiply(new BigDecimal(Constants.ONE_HUNDRED))); + // 转账总笔数 + postMap.put(WechatConstants.TOTAL_NUM, Constants.ONE); + List<Map<String, Object>> list = new ArrayList<>(); + Map<String, Object> subMap = new HashMap<>(4); + // 商家明细单号 该商家下唯一 + // subMap.put("out_detail_no", RandomUtil.randomString(32)) + subMap.put(WechatConstants.OUT_DETAIL_NO, SNOW_FLAKE_ID_WORKER.nextId()); + // 转账金额 + subMap.put(WechatConstants.TRANSFER_AMOUNT, orderMoney); + // 转账备注 + subMap.put(WechatConstants.TRANSFER_REMARK, transferRemark); + // 用户在直连商户应用下的用户标示 + subMap.put(WechatConstants.OPEN_ID, openId); + // 大金额需要传入真实姓名 + /*subMap.put("user_name", + RsaCryptoUtil.encryptOAEP(userName,WechatPayV3Util.getSaveCertificates(privatekeypath)))*/ + list.add(subMap); + postMap.put(WechatConstants.TRANSFER_DETAIL_LIST, list); + // 使用类加载器获取资源 URL + ClassPathResource classPathResource = new ClassPathResource("vx/apiclient_key.pem"); + /*// 获取 resources 目录下的文件路径,假设文件路径为 "resources/data/example.txt" + String filePath = "resources/data/vx/apiclient_key.pem"; + File file = new File(filePath); + // 输出文件的绝对路径 + String absolutePath = file.getAbsolutePath();*/ + String result = HttpUtil.postTransBatRequest( + WechatConstants.WE_CHAT_URL_PRE, + JSONObject.toJSONString(postMap), + // 支付证书序列号 + wechatPayserialNo, + // 商户号 + mchId, + classPathResource.getPath(), WechatConstants.WE_CHAT_URL_SUF); + JSONObject jsonObject = JSONObject.parseObject(result); + /* + * 成功示例 + * { + * "out_batch_no": "plfk2020042013", + * "batch_id": "1030000071100999991182020050700019480001", + * "create_time": "2015-05-20T13:29:35.120+08:00" + * } + */ + if (null == jsonObject || null != jsonObject.get(WechatConstants.CREATE_TIME)) { + //转账成功 + return Boolean.TRUE; + } else { + return Boolean.FALSE; + } + } + } -- Gitblit v1.7.1