From 65e5e0a89ae66f3966290af58db5ed82f66531c1 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 07 Sep 2022 10:23:26 +0800
Subject: [PATCH] 20220902
---
src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java | 233 ++++++++++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 200 insertions(+), 33 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 5521f37..7ea2f40 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,39 +1,46 @@
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.DataDictionaryCustom;
-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.DataDictionaryCustomMapper;
-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.binarywang.wx.miniapp.bean.WxMaSubscribeMessage;
-import cn.binarywang.wx.miniapp.config.impl.WxMaDefaultConfigImpl;
import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.text.StrFormatter;
+import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
+import cn.hutool.extra.spring.SpringUtil;
+import cn.hutool.http.HttpRequest;
+import cn.hutool.http.HttpResponse;
+import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
-import cn.hutool.log.Log;
-import com.alibaba.fastjson.JSON;
+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 cn.hutool.core.io.FileUtil;
-import java.io.IOException;
+import java.io.*;
import java.math.BigDecimal;
+import java.net.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
@@ -41,6 +48,7 @@
@Slf4j
@Service
+@RequiredArgsConstructor
public class XcxPayServiceImpl implements IXcxPayService {
@Autowired
@@ -52,11 +60,94 @@
@Autowired
private DataDictionaryCustomMapper dataDictionaryCustomMapper;
@Autowired
- RedisUtils redisUtils;
+ private MallMoneyFlowMapper mallMoneyFlowMapper;
@Autowired
- private SpringContextHolder springContextHolder;
+ 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 {
@@ -86,12 +177,12 @@
OrderStateMsgVo orderStateMsgVo = new OrderStateMsgVo();
orderStateMsgVo.setTouser(info.getOpenId());//用户的openId
orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id
- 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.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);
@@ -135,12 +226,12 @@
OrderStateMsgVo orderStateMsgVo = new OrderStateMsgVo();
orderStateMsgVo.setTouser(info.getOpenId());//用户的openId
orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id
- 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.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);
@@ -160,6 +251,82 @@
return wxTemplates;
}
+ @Override
+ public FebsResponse generateQrCode(WxGenerateQrCodeDto wxGenerateQrCodeDto) {
+ String randomNum = MallUtils.getRandomNum(5);
+ String imgName="user_" + randomNum + "_acode_1.jpg";
+ String codeImgPath = generateAcode(wxGenerateQrCodeDto.getScene(), wxGenerateQrCodeDto.getPage(), imgName, "800px", null);
+ return new FebsResponse().success().data(codeImgPath);
+ }
+
+
+ /**
+ * 生成小程序码
+ * @param scene 参数
+ * @param path 跳转路径
+ * @param imgName 图片唯一名称
+ * @return
+ */
+ //图片上传路径
+ public static final String IMG_UPLOAD_PATH="/mnt/sdc/webresource/groupbuy/wxcode";
+ public String generateAcode(String scene,String path,String imgName,String width, Integer type){
+ String urlPrefix="http://hwfile.csxuncong.com/groupbuy/wxcode";
+ String imgPath=IMG_UPLOAD_PATH+imgName;
+ if(!FileUtil.exist(imgPath)){
+
+ cn.hutool.json.JSONObject obj = JSONUtil.createObj();
+ //调用二维码接口
+ String url = null;
+ if (type == null) {
+ // 该接口无数量限制,但是 scene 传参最大字符长度为32个字符
+ url = StrFormatter.format("https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token={}",redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY).toString());
+ obj.put("scene", scene);
+ obj.put("path", path);
+ } else {
+ // 该接口存在数量限制, 总共可生成10w个, 但参数是接在path后面
+ url = StrFormatter.format("https://api.weixin.qq.com/wxa/getwxacode?access_token={}", redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY).toString());
+ obj.put("path", path + "?" + scene );
+ }
+
+ //最小 280px,最大 1280px
+ obj.put("width", width);
+ obj.put("auto_color", false);
+ cn.hutool.json.JSONObject obj2 = JSONUtil.createObj();
+ obj2.put("r", 0);
+ obj2.put("g", 0);
+ obj2.put("b", 0);
+ obj.put("line_color", obj2);
+ //是否需要透明底色,为 true 时,生成透明底色的小程序码
+ obj.put("is_hyaline", false);
+ try {
+ HttpResponse execute = HttpRequest.post(url).body(obj.toString(), "application/json").execute();
+ InputStream inputStream = execute.bodyStream();
+ File file = new File(imgPath);
+ FileUtil.writeFromStream(inputStream, file);
+ long uploadUrl = FileUtil.size(file);
+ //小于10kb重新生成
+ if(uploadUrl<=10240){
+ log.error("生成微信小程序码失败:图片大小异常:{}",uploadUrl);
+ return null;
+ }
+ } catch (Exception e) {
+ log.error("生成微信小程序码失败",e);
+ return null;
+ }
+
+ }else {
+ //判断文件是否正常 不正常 删除
+ File file = new File(imgPath);
+ long uploadUrl = FileUtil.size(file);
+ if(uploadUrl<=10240){
+ FileUtil.del(file);
+ return null;
+ }
+ }
+ log.debug("生成微信小程序码成功,路径:" + imgPath);
+ return urlPrefix+"/"+imgName;
+ }
+
/**
* 根据用户ID和订单ID获取所购买商品名称
* @return 所含商品名称(多个以","隔开)
--
Gitblit v1.9.1