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 | 190 ++++++++++++++++++++++++++++++++++++----------- 1 files changed, 144 insertions(+), 46 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 de55fee..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 @@ -5,26 +5,25 @@ 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.MallUtils; -import cc.mrbird.febs.common.utils.OssUtils; -import cc.mrbird.febs.common.utils.RedisUtils; -import cc.mrbird.febs.common.utils.SpringContextHolder; +import cc.mrbird.febs.common.utils.*; import cc.mrbird.febs.mall.dto.ApiRechargeWalletDto; -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.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.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 com.baomidou.dynamic.datasource.toolkit.Base64; @@ -37,6 +36,7 @@ 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.*; import java.math.BigDecimal; @@ -59,6 +59,10 @@ WeixinServiceUtil weixinServiceUtil; @Autowired private DataDictionaryCustomMapper dataDictionaryCustomMapper; + @Autowired + private MallMoneyFlowMapper mallMoneyFlowMapper; + @Autowired + private MallMemberWithdrawMapper mallMemberWithdrawMapper; private final IMallMoneyFlowService mallMoneyFlowService; @Autowired RedisUtils redisUtils; @@ -89,8 +93,60 @@ money, MoneyFlowTypeEnum.RECHARGE.getValue(), rechargeNo, - FlowTypeEnum.BALANCE.getValue()); + 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 @@ -122,12 +178,11 @@ orderStateMsgVo.setTouser(info.getOpenId());//用户的openId orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id orderStateMsgVo.setPage(info.getPage()); - 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())); + 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); @@ -172,7 +227,7 @@ orderStateMsgVo.setTouser(info.getOpenId());//用户的openId orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id orderStateMsgVo.setPage(info.getPage()); - Map<String, WxTemplateData> m = new HashMap<>(5); + 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())); @@ -198,35 +253,78 @@ @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(); + 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 ); } - } catch (IOException e) { - throw new ApiException("生成二维码失败"); + + //最小 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; + } } - return new FebsResponse().success().data(base64); + log.debug("生成微信小程序码成功,路径:" + imgPath); + return urlPrefix+"/"+imgName; } /** -- Gitblit v1.9.1