From 092ad23fb34e22ae7ccc1b1bcd6254c0944f6fdd Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 19 Aug 2022 16:07:45 +0800
Subject: [PATCH] 20220810

---
 src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java |  137 +++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 123 insertions(+), 14 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..82078ae 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,30 +1,41 @@
 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.properties.XcxProperties;
+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.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.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.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.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;
@@ -34,11 +45,13 @@
 public class XcxPayServiceImpl implements IXcxPayService {
 
     @Autowired
-    MallOrderInfoMapper mallOrderInfoMapper;
+    private MallOrderInfoMapper mallOrderInfoMapper;
     @Autowired
-    MallMemberMapper mallMemberMapper;
+    private MallMemberMapper mallMemberMapper;
     @Autowired
     WeixinServiceUtil weixinServiceUtil;
+    @Autowired
+    private DataDictionaryCustomMapper dataDictionaryCustomMapper;
     @Autowired
     RedisUtils redisUtils;
     @Autowired
@@ -67,15 +80,14 @@
     }
 
     @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());
-
+        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()));
@@ -83,8 +95,105 @@
         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);
+        //拼接推送的模版
+        /**
+         * {
+         *   "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<>(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;
+    }
+
+    @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);
     }
 
     /**

--
Gitblit v1.9.1