From 720c9faf1c5796f7a306d394f579909bea4cad15 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期四, 17 四月 2025 10:42:06 +0800 Subject: [PATCH] 提现代码 --- ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/service/impl/WithdrawServiceImpl.java | 191 +---------------------------------------------- 1 files changed, 6 insertions(+), 185 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 c88f7b1..88bdf65 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,40 +4,19 @@ 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.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; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.InputStream; import java.io.UnsupportedEncodingException; -import java.math.BigDecimal; import java.net.URLEncoder; -import java.util.*; -import java.util.stream.Collectors; +import java.util.List; /** * <p> @@ -48,44 +27,10 @@ * @since 2024-05-29 */ @Service -public class WithdrawServiceImpl extends ServiceImpl<WithdrawMapper, Withdraw> implements WithdrawService { - - @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; +public class WithdrawServiceImpl implements WithdrawService { @Override - public R<String> excelExport(WithdrawExportRequest exportRequest, HttpServletResponse response) { + public R<String> excelExport(List<com.ruoyi.order.api.entity.UserWithdrawRecordVO> data, HttpServletResponse response) { try { response.setCharacterEncoding(Constants.UTF8); response.setContentType("application/vnd.ms-excel"); @@ -96,16 +41,8 @@ return R.fail("excel导出失败!"); } try { - 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); + if (null == data) { + throw new GlobalException("excel导出失败,请检查所筛选数据是否正确!"); } // excel模板封装 ExcelWriterBuilder excelWriterBuilder = EasyExcelFactory.write(response.getOutputStream()); @@ -114,7 +51,7 @@ // 自动释放资源 try (ExcelWriter excelWriter = excelWriterBuilder.withTemplate(stream).build()) { WriteSheet writeSheet = EasyExcelFactory.writerSheet().build(); - excelWriter.fill(list, writeSheet); + excelWriter.fill(data, writeSheet); excelWriter.finish(); } catch (Exception e) { return R.fail("excel导出失败!"); @@ -123,122 +60,6 @@ throw new RuntimeException(e); } return R.ok(); - } - - @Override - public BigDecimal withdrawalTotalMoney(List<String> cityList,String startDateStr, String endDateStr) { - return baseMapper.withdrawalTotalMoney(cityList,startDateStr,endDateStr); - } - - @Override - public BigDecimal withdrawalTotalMoneyByYear(List<String> cityList) { - return baseMapper.withdrawalTotalMoneyByYear(cityList); - } - - @Override - public BigDecimal withdrawalTotalMoneyByMonth(List<String> cityList) { - return baseMapper.withdrawalTotalMoneyByMonth(cityList); - } - - @Override - public IPage<UserWithdrawRecordVO> withdrawList(Integer userId, Page<UserWithdrawRecordVO> page) { - return baseMapper.withdrawList(userId, page); - } - - @Override - public Boolean enableProcess(Integer enableProcess) { - Integer[] state = {0, 1}; - boolean contains = Arrays.stream(state).collect(Collectors.toList()).contains(enableProcess); - if (!contains) { - throw new GlobalException("系统设置关闭/开启审核状态异常!"); - } - return withdrawalSettingService.lambdaUpdate().set(WithdrawalSetting::getEnableProcess, enableProcess).update(); - } - - @Override - 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.getId()).list(); - List<Integer> stateList = list.stream().map(Withdraw::getState).collect(Collectors.toList()); - 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