From 77a12468215a8a8a5b3a22544bdcc239efddf287 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 12 Aug 2022 14:26:51 +0800
Subject: [PATCH] 20220810
---
src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java | 55 +++++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 51 insertions(+), 4 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 40d6e17..67a8a57 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,11 +1,14 @@
package cc.mrbird.febs.pay.service.impl;
+import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
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;
@@ -15,7 +18,12 @@
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.json.JSONUtil;
import cn.hutool.log.Log;
+import com.alibaba.fastjson.JSON;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections.CollectionUtils;
import org.springframework.beans.factory.annotation.Autowired;
@@ -24,7 +32,9 @@
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;
+import java.io.IOException;
import java.math.BigDecimal;
+import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@@ -39,6 +49,8 @@
MallMemberMapper mallMemberMapper;
@Autowired
WeixinServiceUtil weixinServiceUtil;
+ @Autowired
+ DataDictionaryCustomMapper dataDictionaryCustomMapper;
@Autowired
RedisUtils redisUtils;
@Autowired
@@ -67,15 +79,13 @@
}
@Override
- public String pushOrderToAddress(OrderStateDto info) {
+ public void pushOrderToAddress(OrderStateDto info) {
RestTemplate restTemplate = new RestTemplate();
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()));
@@ -83,8 +93,45 @@
m.put("thing13", new WxTemplateData(info.getAddressArea()));
m.put("thing16", new WxTemplateData(info.getTakeCode()));
orderStateMsgVo.setData(m);
+ String s = JSONUtil.toJsonStr(orderStateMsgVo);
+ log.info(s);
ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, orderStateMsgVo, String.class);
- return responseEntity.getBody();
+ 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);
+ //拼接推送的模版
+ OrderStateMsgVo orderStateMsgVo = new OrderStateMsgVo();
+ orderStateMsgVo.setToUser(info.getOpenId());//用户的openId
+ orderStateMsgVo.setTemplateId(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.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;
}
/**
--
Gitblit v1.9.1