From 3064a503bc6d0030c1f812d57c4ba2cb7a650fea Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Fri, 02 Sep 2022 14:27:45 +0800 Subject: [PATCH] 20220822 --- src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java | 246 +++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 219 insertions(+), 27 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java index c91cfab..b41bbb9 100644 --- a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java @@ -1,50 +1,148 @@ package cc.mrbird.febs.pay.service.impl; +import cc.mrbird.febs.common.entity.FebsResponse; +import cc.mrbird.febs.common.enumerates.DataDictionaryEnum; +import cc.mrbird.febs.common.enumerates.FlowTypeEnum; +import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum; import cc.mrbird.febs.common.properties.XcxProperties; -import cc.mrbird.febs.common.utils.RedisUtils; -import cc.mrbird.febs.common.utils.SpringContextHolder; -import cc.mrbird.febs.mall.entity.MallMember; -import cc.mrbird.febs.mall.entity.MallOrderInfo; -import cc.mrbird.febs.mall.entity.MallOrderItem; -import cc.mrbird.febs.mall.mapper.MallMemberMapper; -import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper; -import cc.mrbird.febs.pay.model.BrandWCPayRequestData; -import cc.mrbird.febs.pay.model.OrderStateDto; -import cc.mrbird.febs.pay.model.OrderStateMsgVo; -import cc.mrbird.febs.pay.model.WxTemplateData; +import cc.mrbird.febs.common.utils.*; +import cc.mrbird.febs.mall.dto.ApiRechargeWalletDto; +import cc.mrbird.febs.mall.dto.RechargeWalletMessageSendDto; +import cc.mrbird.febs.mall.entity.*; +import cc.mrbird.febs.mall.mapper.*; +import cc.mrbird.febs.mall.service.IMallMoneyFlowService; +import cc.mrbird.febs.mall.vo.RechargeWalletMessageSendVo; +import cc.mrbird.febs.pay.model.*; import cc.mrbird.febs.pay.service.IXcxPayService; import cc.mrbird.febs.pay.util.WechatConfigure; import cc.mrbird.febs.pay.util.WeixinServiceUtil; -import cn.hutool.log.Log; +import cn.hutool.core.collection.CollUtil; +import cn.hutool.core.util.IdUtil; +import cn.hutool.core.util.ObjectUtil; +import cn.hutool.core.util.StrUtil; +import cn.hutool.json.JSONObject; +import cn.hutool.json.JSONUtil; +import com.baomidou.dynamic.datasource.toolkit.Base64; +import com.baomidou.mybatisplus.extension.exceptions.ApiException; +import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.commons.collections.CollectionUtils; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Value; +import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Service; import org.springframework.web.client.RestTemplate; +import java.io.*; import java.math.BigDecimal; +import java.net.*; +import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; @Slf4j @Service +@RequiredArgsConstructor public class XcxPayServiceImpl implements IXcxPayService { @Autowired - MallOrderInfoMapper mallOrderInfoMapper; + private MallOrderInfoMapper mallOrderInfoMapper; @Autowired - MallMemberMapper mallMemberMapper; + private MallMemberMapper mallMemberMapper; @Autowired WeixinServiceUtil weixinServiceUtil; @Autowired - RedisUtils redisUtils; + private DataDictionaryCustomMapper dataDictionaryCustomMapper; @Autowired - private SpringContextHolder springContextHolder; + private MallMoneyFlowMapper mallMoneyFlowMapper; + @Autowired + private MallMemberWithdrawMapper mallMemberWithdrawMapper; + private final IMallMoneyFlowService mallMoneyFlowService; + @Autowired + RedisUtils redisUtils; + + private final SpringContextHolder springContextHolder; private final XcxProperties xcxProperties = SpringContextHolder.getBean(XcxProperties.class); + + @Override + public BrandWCPayRequestData startRechargeWallet(ApiRechargeWalletDto apiRechargeWalletDto) throws Exception { + BigDecimal unit = new BigDecimal("100"); + BigDecimal money = new BigDecimal(apiRechargeWalletDto.getAmount().toString()); + BrandWCPayRequestData payData; + String productNames = "小程序充值"; + MallMember mallMember = mallMemberMapper.selectById(apiRechargeWalletDto.getMemberId()); + String rechargeNo = "CZ_"+MallUtils.getOrderNum(); + Boolean debug = xcxProperties.getDebug(); + String attrStr = "{'rechargeNo':"+rechargeNo+",'memberId':"+mallMember.getId()+"}"; + if (debug) { + payData = weixinServiceUtil.createRechargeWallet("[测试]" + productNames, rechargeNo, + 1, mallMember.getOpenId(), attrStr); + } else { + payData = weixinServiceUtil.createRechargeWallet(productNames, rechargeNo, + unit.multiply(money).intValue(),mallMember.getOpenId(), attrStr); + } + mallMoneyFlowService.addMoneyFlow( + mallMember.getId(), + money, + MoneyFlowTypeEnum.RECHARGE.getValue(), + rechargeNo, + FlowTypeEnum.BALANCE.getValue(), + "余额充值",1); + return payData; + } + + @Override + public void rechargeWalletMessageSend(RechargeWalletMessageSendDto info) { + RestTemplate restTemplate = new RestTemplate(); + String url = WechatConfigure.SEND_INFO_URL + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY); + //拼接推送的模版 + RechargeWalletMessageSendVo orderStateMsgVo = new RechargeWalletMessageSendVo(); + orderStateMsgVo.setTouser(info.getOpenId());//用户的openId + orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id + orderStateMsgVo.setPage(info.getPage()); + Map<String, WxTemplateData> m = new HashMap<>(4); + m.put("character_string1", new WxTemplateData(info.getRechargeNo())); + m.put("amount3", new WxTemplateData(info.getRechargeAmount())); + m.put("amount4", new WxTemplateData(info.getBalance())); + m.put("date5", new WxTemplateData(info.getCreateTime())); + orderStateMsgVo.setData(m); + String s = JSONUtil.toJsonStr(orderStateMsgVo); + log.info(s); + ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, orderStateMsgVo, String.class); + log.info(responseEntity.getBody()); + + } + + @Override + public Boolean memberWithdrawal(MemberWithdrawalDto info) { + log.info("后台同意提现申请..."+JSONUtil.toJsonStr(info)); + boolean flag=false; + BigDecimal unit = new BigDecimal("100"); + BigDecimal money = new BigDecimal(info.getTotalFee().toString()); + String outTradeNo = info.getOutTradeNo(); + String openid = info.getOpenid(); + String desc = info.getDesc(); + + MallMember mallMember = mallMemberMapper.selectMemberByOpenId(openid); + if(ObjectUtil.isEmpty(mallMember)){ + return flag; + } + MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectByWithDrawNoAndMemberIdAndState(outTradeNo,mallMember.getId(),1); + if(ObjectUtil.isEmpty(mallMemberWithdraw)){ + return flag; + } + Boolean debug = xcxProperties.getDebug(); + if (debug) { + flag = weixinServiceUtil.comPay("[测试]" + desc, outTradeNo, + 1, openid); + } else { + flag = weixinServiceUtil.comPay(desc, outTradeNo, + unit.multiply(money).intValue(),openid); + } + return flag; + } @Override public BrandWCPayRequestData startPayment(MallOrderInfo mallOrderInfo) throws Exception { @@ -72,21 +170,115 @@ String url = WechatConfigure.SEND_INFO_URL + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY); //拼接推送的模版 OrderStateMsgVo orderStateMsgVo = new OrderStateMsgVo(); - orderStateMsgVo.setToUser(info.getOpenId());//用户的openId - orderStateMsgVo.setTemplateId(info.getTemplateId());//订阅消息模板id -// wxMssVo.setPage("pages/appointment/line_up?"+"shopId="+info.getShopId()); - - Map<String, WxTemplateData> m = new HashMap<>(5); - m.put("character_string1", new WxTemplateData(info.getOrderNo())); - m.put("thing9", new WxTemplateData(info.getGoodsName())); - m.put("phrase2", new WxTemplateData(info.getOrderState())); - m.put("thing13", new WxTemplateData(info.getAddressArea())); - m.put("thing16", new WxTemplateData(info.getTakeCode())); + orderStateMsgVo.setTouser(info.getOpenId());//用户的openId + orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id + orderStateMsgVo.setPage(info.getPage()); + Map<String, WxTemplateData> m = new HashMap<>(4); + m.put("character_string2", new WxTemplateData(info.getOrderNo())); + m.put("thing11", new WxTemplateData(info.getGoodsName())); + m.put("amount1", new WxTemplateData(info.getAmount())); + m.put("character_string9", new WxTemplateData(info.getTakeCode())); orderStateMsgVo.setData(m); + String s = JSONUtil.toJsonStr(orderStateMsgVo); + log.info(s); ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, orderStateMsgVo, String.class); log.info(responseEntity.getBody()); } + private static final String WXAPPLETURl="https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token="; + + @Override + public void uniformMessageSend(OrderStateDto info) { + RestTemplate restTemplate = new RestTemplate(); + String url = WXAPPLETURl + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY); + //拼接推送的模版 + /** + * { + * "touser": "oJkRK4_pWN2kjp75B_G6oGSWawj0", + * "template_id": "Yk3_M11Pw5rablln7kQBpasfG9ynRNwD9OKsyvUSoWg", + * "page": "index", + * "miniprogram_state":"developer", + * "lang":"zh_CN", + * "data": { + * "character_string1": { + * "value": "2022081214472943380" + * }, + * "thing16": { + * "value": "22704967" + * }, + * "thing9": { + * "value": "商品" + * }, + * "thing13": { + * "value": "测试" + * }, + * "phrase2": { + * "value": "已送达" + * } + * } + * } + */ + OrderStateMsgVo orderStateMsgVo = new OrderStateMsgVo(); + orderStateMsgVo.setTouser(info.getOpenId());//用户的openId + orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id + orderStateMsgVo.setPage(info.getPage()); + Map<String, WxTemplateData> m = new HashMap<>(4); + m.put("character_string2", new WxTemplateData(info.getOrderNo())); + m.put("thing11", new WxTemplateData(info.getGoodsName())); + m.put("amount1", new WxTemplateData(info.getAmount())); + m.put("character_string9", new WxTemplateData(info.getTakeCode())); + orderStateMsgVo.setData(m); + String s = JSONUtil.toJsonStr(orderStateMsgVo); + log.info(s); + ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, orderStateMsgVo, String.class); + log.info(responseEntity.getBody()); + } + + @Override + public List<String> getTemplateId() { + List<String> wxTemplates = new ArrayList<>(); + List<DataDictionaryCustom> wxTemplateList = dataDictionaryCustomMapper.selectDicByType(DataDictionaryEnum.WX_TEMPLATE_ID_ONE.getType()); + if(CollUtil.isNotEmpty(wxTemplateList)){ + for(DataDictionaryCustom dic : wxTemplateList){ + wxTemplates.add(dic.getValue()); + } + } + return wxTemplates; + } + + @Override + public FebsResponse generateQrCode(WxGenerateQrCodeDto wxGenerateQrCodeDto) { + String base64 = null; + try { + RestTemplate restTemplate = new RestTemplate(); + String url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY); + Map<String, Object> params = new HashMap<>(); + params.put("scene", wxGenerateQrCodeDto.getScene()); + params.put("page", wxGenerateQrCodeDto.getPage()); + params.put("width", 430); + ResponseEntity<byte[]> responseEntity = restTemplate.postForEntity(url, params, byte[].class); + if (responseEntity.getStatusCode() == HttpStatus.OK) { + byte[] body = responseEntity.getBody(); + InputStream inputStream = new ByteArrayInputStream(body); + // 将获取流转为base64格式 + byte[] data = null; + ByteArrayOutputStream swapStream = new ByteArrayOutputStream(); + byte[] buff = new byte[100]; + int rc = 0; + while ((rc = inputStream.read(buff, 0, 100)) > 0) { + swapStream.write(buff, 0, rc); + } + data = swapStream.toByteArray(); + base64 = Base64.byteArrayToBase64(data); + inputStream.close(); + swapStream.close(); + } + } catch (IOException e) { + throw new ApiException("生成二维码失败"); + } + return new FebsResponse().success().data(base64); + } + /** * 根据用户ID和订单ID获取所购买商品名称 * @return 所含商品名称(多个以","隔开) -- Gitblit v1.9.1