From 9526971c403417c1c007804f24884c443b9e6cd7 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期三, 04 九月 2024 00:34:40 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java |  325 ++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 209 insertions(+), 116 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 3530a37..089b629 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,11 +1,14 @@
 package com.ruoyi.web.component;
 
 import com.alibaba.fastjson2.JSON;
+import com.alibaba.fastjson2.JSONObject;
 import com.fasterxml.jackson.databind.ObjectMapper;
+import com.google.gson.Gson;
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.enums.ServiceFromEnum;
 import com.ruoyi.common.utils.RSAPublicKeyExample;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.common.utils.http.HttpUtils;
 import com.ruoyi.web.task.PhoneTask;
 import com.smartor.common.SendService;
 import com.smartor.config.RobotPhoneUtils;
@@ -14,10 +17,7 @@
 import com.smartor.mapper.ServiceTaskMapper;
 import com.smartor.mapper.SvyTaskMapper;
 import com.smartor.mapper.SvyTaskSingleMapper;
-import com.smartor.service.IBaseSmsaccountService;
-import com.smartor.service.IIvrTaskTemplateService;
-import com.smartor.service.IServiceSubtaskRecordService;
-import com.smartor.service.ISvyTaskTemplateService;
+import com.smartor.service.*;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
@@ -41,26 +41,38 @@
     @Value("${pub_key}")
     private String pub_key;
 
+    @Value("${localIP}")
+    private String localIP;
+
     @Value("${req_path}")
     private String req_path;
 
-    private static IIvrTaskTemplateService ivrTaskTemplateService;
-
-    private static ServiceSubtaskMapper ivrTaskcallMapper;
-
-    private static ServiceTaskMapper ivrTaskMapper;
-
-    private static SendService sendService;
-
-    private static RedisCache redisCache;
-
-    private static RobotPhoneUtils robotPhoneUtils;
+    @Value("${thirdWXUrl}")
+    private String thirdWXUrl;
 
     @Autowired
-    private SvyTaskMapper svyTaskMapper;
+    private IIvrTaskTemplateService ivrTaskTemplateService;
 
     @Autowired
-    private SvyTaskSingleMapper svyTaskSingleMapper;
+    private ServiceSubtaskMapper ivrTaskcallMapper;
+
+    @Autowired
+    private ServiceTaskMapper ivrTaskMapper;
+
+    @Autowired
+    private SendService sendService;
+
+    @Autowired
+    private RedisCache redisCache;
+
+    @Autowired
+    private RobotPhoneUtils robotPhoneUtils;
+
+    @Autowired
+    private ServiceTaskMapper svyTaskMapper;
+
+    @Autowired
+    private ServiceSubtaskMapper serviceSubtaskMapper;
 
     @Autowired
     private ISvyTaskTemplateService iSvyTaskTemplateService;
@@ -78,40 +90,11 @@
         super(listenerContainer);
     }
 
-
-    @Autowired
-    public void setIIvrTaskTemplateService(IIvrTaskTemplateService ivrTaskTemplateService) {
-        RedisMqReceiver.ivrTaskTemplateService = ivrTaskTemplateService;
-    }
-
-    @Autowired
-    public void setRobotPhoneUtilsService(RobotPhoneUtils robotPhoneUtils) {
-        RedisMqReceiver.robotPhoneUtils = robotPhoneUtils;
-    }
-
-    @Autowired
-    public void setSendService(SendService sendService) {
-        RedisMqReceiver.sendService = sendService;
-    }
-
-    @Autowired
-    public void setIvrTaskcallMapper(ServiceSubtaskMapper ivrTaskcallMapper) {
-        RedisMqReceiver.ivrTaskcallMapper = ivrTaskcallMapper;
-    }
-
-    @Autowired
-    public void setIvrTaskMapper(ServiceTaskMapper ivrTaskMapper) {
-        RedisMqReceiver.ivrTaskMapper = ivrTaskMapper;
-    }
-
-    @Autowired
-    public void setRedisCache(RedisCache redisCache) {
-        RedisMqReceiver.redisCache = redisCache;
-    }
-
     @Override
     public void onMessage(Message message, byte[] pattern) {
         log.info("鐩戝惉Redis key杩囨湡锛宬ey锛歿}锛宑hannel锛歿}", message.toString(), new String(pattern));
+        String ip = localIP;
+        log.error("鏈満鐨勭綉缁淚P涓�:{}", ip);
         String content = message.toString();
         //鍒ゆ柇鏄笉鏄换鍔′俊鎭紝濡傛灉涓嶆槸锛岀洿鎺ヨ繑鍥烇紝涓嶉渶瑕佹墽琛�
         if (!content.contains("taskid")) {
@@ -126,17 +109,23 @@
             } else {
                 commonTaskcallMQ = mapper.readValue(content, CommonTaskcallMQ.class);
             }
-
             if (commonTaskcallMQ.getTaskType() == 1) {
                 //闅忚
-                sfHandle((commonTaskcallMQ));
+                sfHandle(commonTaskcallMQ, ip);
             } else if (commonTaskcallMQ.getTaskType() == 2) {
                 //闂嵎
-                wjHandle(commonTaskcallMQ);
+                wjHandle(commonTaskcallMQ, ip);
             } else if (commonTaskcallMQ.getTaskType() == 3) {
                 //瀹f暀
+                xjHandle(commonTaskcallMQ, ip);
             }
-
+            //澶勭悊瀹屾垚锛岀Щ闄edis
+            redisCache.deleteObject(message.toString());
+            //灏嗙姸鎬佹敼鎴愬畬鎴�
+            ServiceTask serviceTask = new ServiceTask();
+            serviceTask.setTaskid(Long.valueOf(commonTaskcallMQ.getTaskid()));
+            serviceTask.setSendState(5);
+            svyTaskMapper.updateServiceTask(serviceTask);
 
         } catch (Exception e) {
             Integer integer = redisCache.getCacheObject(commonTaskcallMQ.getTaskid().toString());
@@ -151,7 +140,6 @@
             log.error("============娑堣垂澶辫触,灏濊瘯娑堟伅琛ュ彂鍐嶆娑堣垂!==============  {}", e.getMessage());
             redisCache.setCacheObject(message.toString(), message.toString(), 60, TimeUnit.SECONDS);
         }
-
     }
 
     /**
@@ -159,7 +147,8 @@
      *
      * @param commonTaskcallMQ
      */
-    private void sfHandle(CommonTaskcallMQ commonTaskcallMQ) {
+    public void sfHandle(CommonTaskcallMQ commonTaskcallMQ, String ip) {
+        log.error("杩涢殢璁夸簡鍚楋紵{}", commonTaskcallMQ);
         //鍒ゆ柇涓�涓媍ommonTaskcallMQ涓殑stopstate鏄惁涓巌vr_task涓殑涓�鑷达紝涓嶄竴鑷达紝鍒欒鏄庢槸鏆傚仠浜�
         ServiceTask ivrTask1 = ivrTaskMapper.selectServiceTaskByTaskid(commonTaskcallMQ.getTaskid());
         if (ivrTask1.getStopState() != commonTaskcallMQ.getStopState()) {
@@ -175,39 +164,72 @@
                 String descByCode = ServiceFromEnum.getDescByCode(Integer.valueOf(serviceFrom));
                 //杩欓噷鍙互鑰冭檻鐢ㄧ瓥鐣ユā寮忎紭鍖栦竴涓嬶紝涓嶇劧澶毦鐪嬩簡
 
-                //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
-                IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
-                ivrTaskTemplateVO.setID(Long.valueOf(commonTaskcallMQ.getTemplateid()));
-                IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
+//                //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
+//                IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
+//                ivrTaskTemplateVO.setId(Long.valueOf(commonTaskcallMQ.getTemplateid()));
+//                IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
 
                 //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
-                ServiceSubtask ivrTaskcall = new ServiceSubtask();
+                ServiceSubtaskVO ivrTaskcall = new ServiceSubtaskVO();
                 ivrTaskcall.setTaskid(commonTaskcallMQ.getTaskid());
-                List<ServiceSubtask> ivrTaskcalls = ivrTaskcallMapper.selectServiceSubtaskList(ivrTaskcall);
+                List<ServiceSubtask> selectServiceSubtaskList = ivrTaskcallMapper.selectServiceSubtaskList(ivrTaskcall);
                 if (descByCode.equals("鐢佃瘽")) {
-                    for (ServiceSubtask ivrTaskcall1 : ivrTaskcalls) {
-                        ServiceTask ivrTask = ivrTaskMapper.selectServiceTaskByTaskid(ivrTaskcall1.getTaskid());
+                    for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) {
+                        ServiceTask ivrTask = ivrTaskMapper.selectServiceTaskByTaskid(serviceSubtask.getTaskid());
                         if (ivrTask.getSendState() != null && ivrTask.getSendState() == 3 || ivrTask.getSendState() != null && ivrTask.getSendState() == 4) {
                             //濡備綍浠诲姟琚�滄殏鍋溾�濇垨鈥滅粓姝⑩��
                             break;
                         }
+                        //鑾峰彇鍒皏alue鍊兼渶灏戠殑key
+                        String key = getKey();
+                        if (commonTaskcallMQ.getSendType().equals("2")) {
+                            //璇存槑鏄珛鍗冲彂閫�
+                            String value = redisCache.getCacheObject("cache-0");
+                            ServiceSubtaskVO serviceSubtask1 = new ServiceSubtaskVO();
+                            serviceSubtask1.setTaskid(commonTaskcallMQ.getTaskid());
+                            List<ServiceSubtask> selectServiceSubtaskList1 = ivrTaskcallMapper.selectServiceSubtaskList(serviceSubtask1);
+                            for (ServiceSubtask serviceSubtask2 : selectServiceSubtaskList1) {
+                                if (StringUtils.isEmpty(value)) {
+                                    value = "," + serviceSubtask2.getId().toString() + ",";
+                                } else {
+                                    value = value + "," + serviceSubtask2.getId().toString() + ",";
+                                }
+                            }
+                            redisCache.setCacheObject("cache-0", value);
+                        } else {
+                            //闈炵珛鍗冲彂閫�
+                            String value = redisCache.getCacheObject(key);
+                            ServiceSubtaskVO serviceSubtask1 = new ServiceSubtaskVO();
+                            serviceSubtask1.setTaskid(commonTaskcallMQ.getTaskid());
+                            List<ServiceSubtask> selectServiceSubtaskList1 = ivrTaskcallMapper.selectServiceSubtaskList(serviceSubtask1);
+                            for (ServiceSubtask serviceSubtask2 : selectServiceSubtaskList1) {
+                                if (StringUtils.isEmpty(value)) {
+                                    value = "," + serviceSubtask2.getId().toString() + ",";
+                                } else {
+                                    value = value + "," + serviceSubtask2.getId().toString() + ",";
+                                }
+                            }
+                            redisCache.setCacheObject(key, value);
+                        }
 
                         //浠诲姟鍙戦�佽褰曪紙杩欎釜浠g爜搴旇鍐欏湪phoneTask涓紝鍏堝啓鍦ㄨ繖锛屽悗闈㈠啀鏀癸級
                         ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
-                        serviceSubtaskRecord.setTaskid(ivrTaskcall1.getTaskid().toString());
+                        serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
                         serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
-                        serviceSubtaskRecord.setTasktype(ivrTaskcall1.getType());
+                        serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
                         serviceSubtaskRecord.setPreachform("3");
                         serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
                         serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
 
-                        //閫氳繃澶氱嚎绋嬬殑鏂瑰紡鍘绘墦鐢佃瘽
-                        executorService.submit(new PhoneTask(ivrTaskcall1, ivrTaskTemplateVO1, redisCache, sendService, phonePath, robotPhoneUtils));
+//                        //閫氳繃澶氱嚎绋嬬殑鏂瑰紡鍘绘墦鐢佃瘽
+//                        executorService.submit(new PhoneTask(serviceSubtask, ivrTaskTemplateVO1, redisCache, sendService, phonePath, robotPhoneUtils));
                     }
                 } else if (descByCode.equals("澶氬獟浣�")) {
                     //澶氬獟浣�
+                    return;
                 } else if (descByCode.equals("绾歌川")) {
                     //绾歌川
+                    return;
                 } else if (descByCode.equals("鐭俊")) {
                     //鐭俊
 //                        http://localhost:8099/followvisit/particty?param1=3&param2=348
@@ -215,19 +237,19 @@
                     RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
                     String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
 
-                    for (ServiceSubtask ivrTaskSingle : ivrTaskcalls) {
-                        String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
+                    for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) {
+                        String patid = rsaPublicKeyExample.encryptedData(serviceSubtask.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("4");
-                        sendMagParam.setUrl(req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid);
+                        sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid + "&param5=false");
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
 
 
                         //浠诲姟鍙戦�佽褰�
                         ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
-                        serviceSubtaskRecord.setTaskid(ivrTaskSingle.getTaskid().toString());
+                        serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
                         serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
-                        serviceSubtaskRecord.setTasktype(ivrTaskSingle.getType());
+                        serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
                         serviceSubtaskRecord.setPreachform("4");
                         serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
                         serviceSubtaskRecord.setResult(aBoolean == true ? "鎴愬姛" : "澶辫触");
@@ -237,27 +259,32 @@
                     //鍏紬鍙�
                     RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
                     String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
-                    for (ServiceSubtask ivrTaskSingle : ivrTaskcalls) {
-                        String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
-                        SendMagParam sendMagParam = new SendMagParam();
-                        sendMagParam.setType("5");
-                        sendMagParam.setUrl(req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                        //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
-                        sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
-                        Map map = new HashMap();
-                        map.put("first", ivrTask1.getTaskName());
-                        sendMagParam.setContent(JSON.toJSONString(map));
-                        Boolean aBoolean = sendService.sendMsg(sendMagParam);
+                    for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) {
+                        String patid = rsaPublicKeyExample.encryptedData(serviceSubtask.getPatid().toString(), pub_key);
+//                        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);
+
+                        String url = ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false";
+                        String wxCode = getWXCode(serviceSubtask.getIdcardno(), url);
 
                         //浠诲姟鍙戦�佽褰�
                         ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
-                        serviceSubtaskRecord.setTaskid(ivrTaskSingle.getTaskid().toString());
+                        serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
                         serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
-                        serviceSubtaskRecord.setTasktype(ivrTaskSingle.getType());
+                        serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
                         serviceSubtaskRecord.setPreachform("4");
                         serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
-                        serviceSubtaskRecord.setResult(aBoolean == true ? "鎴愬姛" : "澶辫触");
+                        serviceSubtaskRecord.setResult("鎴愬姛");
+                        if (wxCode.equals("0")) serviceSubtaskRecord.setResult("澶辫触");
                         serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
                     }
                 }
@@ -271,7 +298,8 @@
      *
      * @param commonTaskcallMQ
      */
-    private void xjHandle(CommonTaskcallMQ commonTaskcallMQ) {
+    private void xjHandle(CommonTaskcallMQ commonTaskcallMQ, String ip) {
+        log.error("杩涘鏁欎簡鍚楋紵{}", commonTaskcallMQ);
         //鍒ゆ柇涓�涓媍ommonTaskcallMQ涓殑stopstate鏄惁涓巌vr_task涓殑涓�鑷达紝涓嶄竴鑷达紝鍒欒鏄庢槸鏆傚仠浜�
         ServiceTask ivrTask1 = ivrTaskMapper.selectServiceTaskByTaskid(commonTaskcallMQ.getTaskid());
         if (ivrTask1.getStopState() != commonTaskcallMQ.getStopState()) {
@@ -288,12 +316,14 @@
                 //杩欓噷鍙互鑰冭檻鐢ㄧ瓥鐣ユā寮忎紭鍖栦竴涓嬶紝涓嶇劧澶毦鐪嬩簡
 
                 //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
-                IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
-                ivrTaskTemplateVO.setID(Long.valueOf(commonTaskcallMQ.getTemplateid()));
-                IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
-
+                IvrTaskTemplateVO ivrTaskTemplateVO1 = null;
+                if (commonTaskcallMQ.getTaskType().equals("1")) {
+                    IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
+                    ivrTaskTemplateVO.setId(Long.valueOf(commonTaskcallMQ.getTemplateid()));
+                    ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
+                }
                 //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
-                ServiceSubtask ivrTaskcall = new ServiceSubtask();
+                ServiceSubtaskVO ivrTaskcall = new ServiceSubtaskVO();
                 ivrTaskcall.setTaskid(commonTaskcallMQ.getTaskid());
                 List<ServiceSubtask> ivrTaskcalls = ivrTaskcallMapper.selectServiceSubtaskList(ivrTaskcall);
                 if (descByCode.equals("鐢佃瘽")) {
@@ -332,7 +362,7 @@
                         String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("4");
-                        sendMagParam.setUrl(req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid);
+                        sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid + "&param5=false");
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
 
                         //浠诲姟鍙戦�佽褰�
@@ -351,17 +381,22 @@
                     String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
                     for (ServiceSubtask ivrTaskSingle : ivrTaskcalls) {
                         String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
-                        SendMagParam sendMagParam = new SendMagParam();
-                        sendMagParam.setType("5");
-                        sendMagParam.setUrl(req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                        //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
-                        sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
-                        Map map = new HashMap();
-                        map.put("first", ivrTask1.getTaskName());
-                        sendMagParam.setContent(JSON.toJSONString(map));
-                        Boolean aBoolean = sendService.sendMsg(sendMagParam);
+//                        SendMagParam sendMagParam = new SendMagParam();
+//                        sendMagParam.setType("5");
+//                        sendMagParam.setUrl(ip + ":" + req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
+//                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChainxj?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(ivrTaskSingle.getOpenid());
+                        //鏂板崕鍖婚櫌鏈夎嚜宸辩殑鍏紬鍙峰彂閫佹帴鍙o紝鎴戜滑鐨勫厛涓嶇敤锛堝厛淇濈暀锛屽叾瀹冮」鐩彲浠ョ敤锛�
+//                        Boolean aBoolean = sendService.sendMsg(sendMagParam);
+//                        log.error("鏄惁鍙戦�佹垚鍔燂細{}", aBoolean);
 
+                        String url = ip + ":" + req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false";
+                        String wxCode = getWXCode(ivrTaskSingle.getIdcardno(), url);
                         //浠诲姟鍙戦�佽褰�
                         ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
                         serviceSubtaskRecord.setTaskid(ivrTaskSingle.getTaskid().toString());
@@ -369,7 +404,11 @@
                         serviceSubtaskRecord.setTasktype(ivrTaskSingle.getType());
                         serviceSubtaskRecord.setPreachform("4");
                         serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
-                        serviceSubtaskRecord.setResult(aBoolean == true ? "鎴愬姛" : "澶辫触");
+                        serviceSubtaskRecord.setResult("鎴愬姛");
+                        if (!wxCode.equals("0")) {
+                            serviceSubtaskRecord.setResult("澶辫触");
+                        }
+
                         serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
                     }
                 }
@@ -383,9 +422,12 @@
      *
      * @param commonTaskcallMQ
      */
-    private void wjHandle(CommonTaskcallMQ commonTaskcallMQ) {
+    private void wjHandle(CommonTaskcallMQ commonTaskcallMQ, String ip) {
+        log.error("杩涢棶鍗蜂簡鍚楋紵{}", commonTaskcallMQ);
         //鍒ゆ柇涓�涓媍ommonTaskcallMQ涓殑stopstate鏄惁涓巌vr_task涓殑涓�鑷达紝涓嶄竴鑷达紝鍒欒鏄庢槸鏆傚仠浜�
-        SvyTask svyTask = svyTaskMapper.selectSvyTaskByTaskid(commonTaskcallMQ.getTaskid());
+        ServiceTask svyTask = svyTaskMapper.selectServiceTaskByTaskid(commonTaskcallMQ.getTaskid());
+        log.error("svyTask.getStopState()鐨勫�间负锛歿} 锛� commonTaskcallMQ.getStopState()鐨勫�间负锛歿}", svyTask.getStopState(), commonTaskcallMQ.getStopState());
+
         if (svyTask.getStopState() != commonTaskcallMQ.getStopState()) {
             //灏嗘秷鎭粠闃熷垪涓墧闄�
             return;
@@ -405,12 +447,13 @@
                 SvyTaskTemplateVO svyTaskTemplateVO1 = iSvyTaskTemplateService.selectInfoByCondition(svyTaskTemplateVO);
 
                 //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
-                SvyTaskSingle svyTaskSingle = new SvyTaskSingle();
-                svyTaskSingle.setTaskid(commonTaskcallMQ.getTaskid());
-                List<SvyTaskSingle> svyTaskSingles = svyTaskSingleMapper.selectSvyTaskSingleList(svyTaskSingle);
+                ServiceSubtaskVO serviceSubtaskVO = new ServiceSubtaskVO();
+                serviceSubtaskVO.setTaskid(commonTaskcallMQ.getTaskid());
+                List<ServiceSubtask> selectServiceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(serviceSubtaskVO);
+                log.error("selectServiceSubtaskList鏁版嵁鏄灏戯紵{}", selectServiceSubtaskList.size());
                 if (descByCode.equals("鐢佃瘽")) {
-                    for (SvyTaskSingle svyTaskSingle1 : svyTaskSingles) {
-                        SvyTask svyTask1 = svyTaskMapper.selectSvyTaskByTaskid(svyTaskSingle1.getTaskid());
+                    for (ServiceSubtask svyTaskSingle1 : selectServiceSubtaskList) {
+                        ServiceTask svyTask1 = svyTaskMapper.selectServiceTaskByTaskid(svyTaskSingle1.getTaskid());
                         if (svyTask1.getSendState() != null && svyTask1.getSendState().equals("3") || svyTask1.getSendState() != null && svyTask1.getSendState().equals("4")) {
                             //濡備綍浠诲姟琚�滄殏鍋溾�濇垨鈥滅粓姝⑩��
                             break;
@@ -434,21 +477,27 @@
                 } else if (descByCode.equals("鐭俊")) {
                     //鐭俊
                 } else if (descByCode.equals("鍏紬鍙�")) {
+                    log.error("杩涢棶鍗峰叕浼楀彿浜嗗悧锛焮}", descByCode);
                     //鍏紬鍙�
                     RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
                     String taskId = rsaPublicKeyExample.encryptedData(svyTask.getTaskid().toString(), pub_key);
-                    for (SvyTaskSingle svyTaskSingle1 : svyTaskSingles) {
+                    for (ServiceSubtask svyTaskSingle1 : selectServiceSubtaskList) {
                         String patid = rsaPublicKeyExample.encryptedData(svyTaskSingle1.getPatid().toString(), pub_key);
+                        String url = ip + ":" + req_path + "/outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName() + "&param5=false";
+                        //杩欎釜鏄垜浠嚜宸辩殑寰俊鍏紬鍙峰彂閫佹柟寮忥紝
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("5");
-                        sendMagParam.setUrl(req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName());
-                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName());
+                        sendMagParam.setUrl(url);
+                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName() + "&param5=false");
                         //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
                         sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
                         Map map = new HashMap();
                         map.put("first", svyTask.getTaskName());
                         sendMagParam.setContent(JSON.toJSONString(map));
+                        sendMagParam.setOpenid(svyTaskSingle1.getOpenid());
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
+                        log.error("鍙戦�佹垚鍔熶簡鍚楋紵{}", aBoolean);
+//                        String wxCode = getWXCode(svyTaskSingle1.getIdcardno(), url);
 
                         //浠诲姟鍙戦�佽褰�
                         ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
@@ -457,7 +506,10 @@
                         serviceSubtaskRecord.setTasktype(svyTaskSingle1.getType());
                         serviceSubtaskRecord.setPreachform("4");
                         serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
-                        serviceSubtaskRecord.setResult(aBoolean == true ? "鎴愬姛" : "澶辫触");
+                        serviceSubtaskRecord.setResult("鎴愬姛");
+//                        if (!wxCode.equals("0")) {
+//                            serviceSubtaskRecord.setResult("澶辫触");
+//                        }
                         serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
                     }
                 }
@@ -467,7 +519,7 @@
     }
 
 
-//    /**
+    //    /**
 //     * 鏈哄櫒浜虹涓�鍙ヨ瘽璇煶
 //     * concurrency = "50"  骞跺彂鏁颁负50
 //     */
@@ -502,5 +554,46 @@
 //            channel.basicReject(message.getMessageProperties().getDeliveryTag(), true);
 //        }
 //    }
+    private String getKey() {
+        Map<String, String> map = new HashMap<>();
+        for (int i = 0; i < 6; i++) {
+            Boolean aBoolean = redisCache.hasKey("cache-" + i);
+            if (!aBoolean) {
+                redisCache.setCacheObject("cache-" + i, "");
+                map.put("cache-" + i, "");
+            } else {
+                map.put("cache-" + i, redisCache.getCacheObject("cache-" + i));
+            }
+        }
+
+        String key = null;
+        String value = "";
+        for (Map.Entry<String, String> entry : map.entrySet()) {
+            if (StringUtils.isEmpty(value)) {
+                value = entry.getValue();
+                key = entry.getKey();
+            } else {
+                if (entry.getValue().split(",").length < value.split(",").length) {
+                    value = entry.getValue();
+                    key = entry.getKey();
+                }
+            }
+        }
+        return key;
+    }
+
+    private String getWXCode(String idcard, String url) {
+        XinHuaWXReq xinHuaWXReq = new XinHuaWXReq();
+        xinHuaWXReq.setIdcard(idcard);
+        xinHuaWXReq.setUrl(url);
+        xinHuaWXReq.setKeyword1(null);
+        xinHuaWXReq.setKeyword2(null);
+        xinHuaWXReq.setKeyword3(null);
+        xinHuaWXReq.setKeyword4(null);
+        String result = HttpUtils.sendPost(thirdWXUrl, new Gson().toJson(xinHuaWXReq));
+        JSONObject jsonObject = JSONObject.parseObject(result);
+        String code = (String) jsonObject.get("code");
+        return code;
+    }
 
 }

--
Gitblit v1.9.3