From 6e34bc4a364b68ab0e62159eecc61bb6b0bf8201 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期五, 09 五月 2025 17:49:58 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java |  193 ++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 146 insertions(+), 47 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java b/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java
index c721b18..24c13c4 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java
@@ -1,17 +1,21 @@
 package com.ruoyi.web.component;
 
-import com.alibaba.fastjson.JSON;
+import afu.org.checkerframework.checker.oigj.qual.O;
 import com.alibaba.fastjson2.JSONObject;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.google.gson.Gson;
+import com.google.gson.GsonBuilder;
 import com.ruoyi.common.core.redis.RedisCache;
+import com.ruoyi.common.enums.MsgLSEnum;
 import com.ruoyi.common.enums.ServiceFromEnum;
+import com.ruoyi.common.enums.WxGZHEnum;
+import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.utils.HttpUtil;
+import com.ruoyi.common.utils.OkHttpExample;
 import com.ruoyi.common.utils.RSAPublicKeyExample;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.http.HttpUtils;
-import com.smartor.common.SendService;
-import com.smartor.config.RobotPhoneUtils;
+import com.smartor.common.LSHospTokenUtil;
 import com.smartor.domain.*;
 import com.smartor.mapper.PatArchiveMapper;
 import com.smartor.mapper.ServiceSubtaskMapper;
@@ -19,9 +23,10 @@
 import com.smartor.service.IBaseSmsaccountService;
 import com.smartor.service.IServiceOutPathService;
 import com.smartor.service.IServiceSubtaskRecordService;
-import com.smartor.service.ISvyTaskTemplateService;
+import com.sun.org.apache.bcel.internal.generic.NEW;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.collections4.CollectionUtils;
+import org.apache.commons.lang3.ObjectUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.data.redis.connection.Message;
@@ -29,13 +34,15 @@
 import org.springframework.data.redis.listener.RedisMessageListenerContainer;
 import org.springframework.stereotype.Component;
 
-import java.net.URLEncoder;
-import java.time.LocalDateTime;
-import java.time.format.DateTimeFormatter;
+import java.io.IOException;
+import java.security.MessageDigest;
 import java.util.*;
 import java.util.concurrent.ExecutorService;
 import java.util.concurrent.Executors;
 import java.util.concurrent.TimeUnit;
+
+import static cn.hutool.core.convert.Convert.numberToWord;
+import static cn.hutool.core.convert.Convert.toHex;
 
 @Slf4j
 @Component//鐩戝惉姝ら槦鍒�
@@ -53,9 +60,6 @@
     @Value("${req_path}")
     private String req_path;
 
-    @Value("${thirdWXUrl}")
-    private String thirdWXUrl;
-
     @Autowired
     private IServiceOutPathService iServiceOutPathService;
 
@@ -72,16 +76,10 @@
     private RedisCache redisCache;
 
     @Autowired
-    private RobotPhoneUtils robotPhoneUtils;
-
-    @Autowired
     private ServiceTaskMapper svyTaskMapper;
 
     @Autowired
     private ServiceSubtaskMapper serviceSubtaskMapper;
-
-    @Autowired
-    private ISvyTaskTemplateService iSvyTaskTemplateService;
 
     @Autowired
     private IServiceSubtaskRecordService serviceSubtaskRecordService;
@@ -92,8 +90,8 @@
     @Value("${xhsmsPath}")
     private String xhsmsPath;
 
-    @Value("${appid}")
-    private String appid;
+    @Value("${visitHosp}")
+    private Integer visitHosp;
 
     // 鍒涘缓鍥哄畾澶у皬鐨勭嚎绋嬫睜
     private static final ExecutorService executorService = Executors.newFixedThreadPool(10);
@@ -357,10 +355,40 @@
                                 sendMagParam.setContent("銆愭柊鍗庡尰闄€�戞偍濂斤紝閭�璇锋偍濉啓鍑洪櫌瀹f暀璋冩煡琛紝璇风偣鍑�" + sendMagParam.getUrl() + "鏌ョ湅銆傛劅璋㈡偍閰嶅悎锛�");
                             }
                             //鐭俊杩橀渶瑕佹ā鏉�
-                            Map<String, String> req = new HashMap<>();
-                            req.put("phone", sendMagParam.getPhone());
-                            req.put("content", sendMagParam.getContent());
-                            String s = HttpUtil.postJsonRequest(xhsmsPath, new Gson().toJson(req));
+                            String s = null;
+                            if (visitHosp == 1) {
+                                //鏂板崕鐨勭煭淇″彂閫佹柟寮�
+                                Map<String, String> req = new HashMap<>();
+                                req.put("phone", sendMagParam.getPhone());
+                                req.put("content", sendMagParam.getContent());
+                                s = HttpUtil.postJsonRequest(xhsmsPath, new Gson().toJson(req));
+                            } else if (visitHosp == 2) {
+                                //涓芥按鐨勭煭淇″彂閫佹柟寮�
+                                String address = MsgLSEnum.getAddressByCode(serviceSubtask.getOrgid());
+                                String token = LSHospTokenUtil.getToken(serviceSubtask.getOrgid());
+                                log.error("-----------token鐨勫�间负锛歿}",token);
+                                if (StringUtils.isEmpty(address)) {
+                                    ServiceSubtask ss = new ServiceSubtask();
+                                    ss.setResult("error");
+                                    ss.setRemark("鐭俊鍙戦�佸け璐�,璇ユ満鏋勬病鏈夐厤缃煭淇″湴鍧�");
+                                    ss.setSendstate(5L);
+                                    ss.setId(serviceSubtask.getId());
+                                    ss.setFinishtime(new Date());
+                                    serviceSubtaskMapper.updateServiceSubtask(ss);
+                                    continue;
+                                }
+                                log.error("---------mq涓芥按鐭俊鍙戦�佸叆鍙俛ddress锛歿},  sendMagParam:{},  orgid:{}-------", address, sendMagParam, serviceSubtask.getOrgid());
+                                String dxCode = getDXCode(address, sendMagParam.getPhone(), sendMagParam.getContent(), "", "", MsgLSEnum.getHeaderByCode(serviceSubtask.getOrgid()),token);
+                                log.error("---------涓芥按鐭俊鍙戦�佺粨鏋滐細{}-------", dxCode);
+                                ObjectMapper objectMapper = new ObjectMapper();
+                                Map<String, Object> textParam = objectMapper.readValue(dxCode, Map.class);
+                                String code = textParam.get("Code").toString();
+                                if (code.equals("0")) {
+                                    s = "true";
+                                } else {
+                                    throw new BaseException(null);
+                                }
+                            }
                             if (s.equals("true")) {
                                 ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
                                 serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
@@ -428,24 +456,6 @@
                         try {
                             SendMagParam sendMagParam = new SendMagParam();
                             sendMagParam.setType("5");
-//                            sendMagParam.setUrl(ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
-//                            log.info("閾炬帴瀹屾暣璺緞锛歿}", ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
-//                            //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
-//                            sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
-//                            Map map = new HashMap();
-//                            map.put("first", ivrTask1.getTaskName());
-//                            sendMagParam.setContent(JSON.toJSONString(map));
-//                            sendMagParam.setOpenid(serviceSubtask.getOpenid());
-//                            Boolean aBoolean = sendService.sendMsg(sendMagParam);
-//
-
-//                            if (type == 1) {
-//                                url = ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
-//                            } else if (type == 2) {
-//                                url = ip + ":" + req_path + "/outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
-//                            } else if (type == 3) {
-//                                url = ip + ":" + req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
-//                            }
                             String url = null;
                             Boolean aBoolean = false;
                             if (type == 1) {
@@ -489,11 +499,43 @@
                                 url = ip + ":" + req_path + "/xj?p=" + format;
                             }
                             PatArchive patArchive = patArchiveMapper.selectPatArchiveByPatid(serviceSubtask.getPatid());
-                            String wxCode = getWXCode(serviceSubtask.getSfzh(), url, serviceSubtask.getTaskName(), serviceSubtask.getTaskDesc(), patArchive.getTelcode(), patArchive.getName(), patArchive.getPatientno());
+                            if (StringUtils.isEmpty(patArchive.getPatidHis())) {
+                                ServiceSubtask ss = new ServiceSubtask();
+                                ss.setResult("error");
+                                ss.setRemark("鍏紬鍙峰彂閫佸け璐�,his绯荤粺鐨勬偅鑰卛d涓虹┖");
+                                ss.setSendstate(5L);
+                                ss.setId(serviceSubtask.getId());
+                                ss.setFinishtime(new Date());
+                                serviceSubtaskMapper.updateServiceSubtask(ss);
+                                continue;
+                            }
+
+                            //鑾峰彇寰俊鍏紬鍙疯姹備俊鎭牴鎹満鏋処D
+                            log.error("鑾峰彇寰俊鍏紬鍙疯姹備俊鎭牴鎹満鏋処D锛歿}", patArchive.getOrgid());
+                            List<String> wxqqxx = WxGZHEnum.getDescByCode(patArchive.getOrgid());
+                            if (CollectionUtils.isEmpty(wxqqxx) || wxqqxx.size() < 4) {
+                                ServiceSubtask ss = new ServiceSubtask();
+                                ss.setResult("error");
+                                ss.setRemark("璇ユ満鏋勭殑鍏紬鍙烽厤缃俊鎭笉鍏紝鏃犳硶閫氳繃鍏紬鍙峰彂閫�");
+                                ss.setSendstate(5L);
+                                ss.setId(serviceSubtask.getId());
+                                ss.setFinishtime(new Date());
+                                serviceSubtaskMapper.updateServiceSubtask(ss);
+                                continue;
+                            }
+
+
+                            String wxCode = getWXCode(serviceSubtask.getSfzh(), url, serviceSubtask.getTaskName(), serviceSubtask.getTaskName(), patArchive.getTelcode(), patArchive.getName(), patArchive.getPatidHis(), wxqqxx);
+                            log.error("wxCode鐨勫�间负:{}", wxCode);
                             Map<String, Object> map = JSONObject.parseObject(wxCode, Map.class);
+                            log.error("map鐨勫�间负:{}", map);
                             if (!map.isEmpty()) {
                                 serviceSubtask.setResult("success");
                                 serviceSubtask.setSendstate(3L);
+                                log.error("aBoolean鐨勫�间负:{}", aBoolean);
+                                if (map.get("succ").toString().equals("true")) {
+                                    aBoolean = true;
+                                }
                                 if (aBoolean == false) {
                                     ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
                                     serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
@@ -502,7 +544,7 @@
                                     serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
                                     serviceSubtaskRecord.setPreachform("5");
                                     serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
-                                    serviceSubtaskRecord.setRemark(map.get("msg").toString());
+                                    serviceSubtaskRecord.setRemark(ObjectUtils.isNotEmpty(map.get("msg")) ? map.get("msg").toString() : null);
                                     lssubIds.add(serviceSubtask.getId());
                                     serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
                                     continue;
@@ -633,22 +675,79 @@
         return key;
     }
 
-    private String getWXCode(String idcard, String url, String taskName, String taskDesc, String phone, String setPatientname, String setPatientid) {
+    private String getWXCode(String idcard, String url, String taskName, String taskDesc, String phone, String patientname, String setPatientid, List<String> wxqqxx) {
         XinHuaWXReq xinHuaWXReq = new XinHuaWXReq();
         xinHuaWXReq.setIdcard(idcard);
         xinHuaWXReq.setUrl(url);
         xinHuaWXReq.setPatientid(setPatientid);
-        xinHuaWXReq.setPatientname(setPatientname);
+        xinHuaWXReq.setPatientname(patientname);
         xinHuaWXReq.setMobile(phone);
         xinHuaWXReq.setMedcardno(null);
         xinHuaWXReq.setTitlename(taskName);
         xinHuaWXReq.setContent(taskDesc);
-        xinHuaWXReq.setAppid(appid);
-        log.error("-----寰俊鍏紬鍙风殑鍑哄樊涓�----锛歿}", xinHuaWXReq);
-        String result = HttpUtils.sendPost(thirdWXUrl, new Gson().toJson(xinHuaWXReq));
+        xinHuaWXReq.setAppid(wxqqxx.get(1));
+        log.error("-----寰俊鍏紬鍙风殑鍑哄弬涓�----锛歿}", xinHuaWXReq);
+//         new Gson().toJson(xinHuaWXReq);
+        GsonBuilder gb = new GsonBuilder();
+        gb.disableHtmlEscaping();
+        String body = gb.create().toJson(xinHuaWXReq);
+
+        log.error("encode鐨勫叆鍙備负wxqqxx 锛歿},   body:{}", wxqqxx.get(2), body);
+        String encode = encode(wxqqxx.get(2).concat(body));
+        log.error("--------encode鐨勫�间负锛歿}-----", encode);
+        Map<String, String> headerMap = new HashMap<>();
+        headerMap.put("sign", encode);
+        String result = HttpUtils.sendPostByHeader(wxqqxx.get(3), body, headerMap);
+        log.error("--------result鐨勫�间负锛歿}-----", result);
+
         JSONObject jsonObject = JSONObject.parseObject(result);
         String code = (String) jsonObject.toString();
         return code;
     }
 
+
+    private String getDXCode(String address, String ShouJiHM, String FaSongNR, String FaSongRID, String FaSongRXM, Map<String, Object> headerMap,String token) {
+        Map<String, Object> map = new LinkedHashMap<>();
+
+        Map<String, Object> YeWuXX = new LinkedHashMap<>();
+        Map<String, Object> DuanXinXX = new LinkedHashMap<>();
+        DuanXinXX.put("ShouJiHM", ShouJiHM);
+        DuanXinXX.put("FaSongNR", FaSongNR);
+        DuanXinXX.put("FaSongRID", FaSongRID);
+        DuanXinXX.put("FaSongRXM", FaSongRXM);
+        YeWuXX.put("DuanXinXX", DuanXinXX);
+
+        map.put("XiaoXiTou", headerMap);
+        map.put("YeWuXX", YeWuXX);
+
+        String body = new Gson().toJson(map);
+
+//        String result = HttpUtils.sendPost(address, body);
+        String result = null;
+        try {
+            result = OkHttpExample.sendPostRequest(address, body, token);
+        } catch (IOException e) {
+            e.printStackTrace();
+        }
+        log.error("--------result鐨勫�间负锛歿}-----", result);
+
+        JSONObject jsonObject = JSONObject.parseObject(result);
+        String code = (String) jsonObject.toString();
+        return code;
+    }
+
+
+    public String encode(String arg) {
+        if (arg == null) {
+            arg = "";
+        }
+        MessageDigest md5 = null;
+        try {
+            md5 = MessageDigest.getInstance("MD5");
+            md5.update(arg.getBytes("UTF-8"));
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return toHex(md5.digest());
+    }
 }

--
Gitblit v1.9.3