From c62e26954e41360fc6a2efc874815aa84f8b0073 Mon Sep 17 00:00:00 2001 From: liusheng <337615773@qq.com> Date: 星期三, 21 五月 2025 14:45:10 +0800 Subject: [PATCH] 代码提交 --- ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java | 212 +++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 158 insertions(+), 54 deletions(-) diff --git a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java index 537d205..dec2f0a 100644 --- a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java +++ b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/RyTask.java @@ -1,8 +1,6 @@ package com.ruoyi.quartz.task; -import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSONObject; -import com.fasterxml.jackson.core.JsonParser; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; import com.google.common.reflect.TypeToken; @@ -10,19 +8,22 @@ import com.google.gson.JsonArray; import com.google.gson.JsonObject; import com.ruoyi.common.core.redis.RedisCache; +import com.ruoyi.common.enums.MsgLSEnum; import com.ruoyi.common.enums.ServiceFromEnum; -import com.ruoyi.common.utils.DtoConversionUtils; +import com.ruoyi.common.enums.VisitSendStateEnum; +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.common.LSHospTokenUtil; import com.smartor.domain.*; import com.smartor.mapper.ServiceSubtaskMapper; import com.smartor.mapper.ServiceTaskMapper; import com.smartor.mapper.SysUserImportMapper; import com.smartor.service.*; -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; @@ -35,12 +36,12 @@ import java.io.File; import java.io.FileWriter; import java.io.IOException; -import java.io.UnsupportedEncodingException; import java.lang.reflect.Type; import java.net.URLEncoder; import java.nio.charset.StandardCharsets; import java.nio.file.Files; import java.nio.file.Paths; +import java.security.MessageDigest; import java.text.ParseException; import java.text.SimpleDateFormat; import java.time.LocalDate; @@ -50,6 +51,8 @@ import java.time.format.DateTimeFormatter; import java.util.*; import java.util.stream.Collectors; + +import static cn.hutool.core.convert.Convert.toHex; /** * 瀹氭椂浠诲姟璋冨害娴嬭瘯 @@ -98,9 +101,6 @@ @Value("${pub_key}") private String pub_key; - @Value("${thirdWXUrl}") - private String thirdWXUrl; - @Value("${req_path}") private String req_path; @@ -142,6 +142,9 @@ @Value("${appid}") private String appid; + + @Value("${server.port}") + private String port; public void ryMultipleParams(String s, Boolean b, Long l, Double d, Integer i) { System.out.println(StringUtils.format("鎵ц澶氬弬鏂规硶锛� 瀛楃涓茬被鍨媨}锛屽竷灏旂被鍨媨}锛岄暱鏁村瀷{}锛屾诞鐐瑰瀷{}锛屾暣褰}", s, b, l, d, i)); @@ -248,11 +251,13 @@ * 澶勭悊鎮h�呬俊鎭紝杩涘叆瀛愪换鍔¤〃 */ public void dealOutHospInfo() { - //鍑洪櫌琛� - iPatMedInhospService.dealOutHospInfo(); - //闂ㄨ瘖琛� - if (visitHosp != 1) { - iPatMedOuthospService.dealOutpatientInfo(); + if (port.equals("8095")) { + //鍑洪櫌琛� + iPatMedInhospService.dealOutHospInfo(); + //闂ㄨ瘖琛� + if (visitHosp != 1) { + iPatMedOuthospService.dealOutpatientInfo(); + } } } @@ -261,22 +266,24 @@ * 澶勭悊鎵嬫湳淇℃伅锛岃繘鍏ュ瓙浠诲姟琛� */ public void dealOperationInfo() { - iPatMedOperationService.dealOperationInfo(); + if (port.equals("8095")) iPatMedOperationService.dealOperationInfo(); + } /** * 澶勭悊鎮h�呬俊鎭紝杩涘叆瀛愪换鍔¤〃(寰俊灏忕▼搴�) */ public void dealOutHospInfoXHC() { - PatMedInhosp patMedInhosp = new PatMedInhosp(); - //鑾峰彇鏈鐞嗙殑鏁版嵁 - List<ServicePatientTemp> servicePatientTemps = iServicePatientTempService.selectServicePatientTempList(new ServicePatientTemp()); - + if (port.equals("8095")) { + PatMedInhosp patMedInhosp = new PatMedInhosp(); + //鑾峰彇鏈鐞嗙殑鏁版嵁 + List<ServicePatientTemp> servicePatientTemps = iServicePatientTempService.selectServicePatientTempList(new ServicePatientTemp()); + } } /** - * 闀挎湡浠诲姟鎵ц锛堢數璇濓級 + * 闀挎湡浠诲姟鎵ц */ public void longTaskSend() { //鑾峰彇浠诲姟淇℃伅 @@ -301,23 +308,15 @@ * @return */ public boolean isDateToday(Date date) { - //濡傛灉缁欑殑鏃ユ湡灏忎簬褰撳墠鏃ユ湡锛屼篃鐩存帴鍙戦�� - LocalDateTime localDateTime = date.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime(); - if (localDateTime.isBefore(LocalDateTime.now())) { - return true; + if (date == null) { + return false; } - // 鑾峰彇褰撳墠鏃ユ湡 - Calendar calendarNow = Calendar.getInstance(); - int todayYear = calendarNow.get(Calendar.YEAR); - int todayMonth = calendarNow.get(Calendar.MONTH); - int todayDay = calendarNow.get(Calendar.DAY_OF_MONTH); - - // 鍒涘缓涓�涓� Calendar 瀹炰緥鐢ㄤ簬妫�鏌ョ殑鏃ユ湡 - Calendar calendarToCheck = Calendar.getInstance(); - calendarToCheck.setTime(date); - - // 姣旇緝骞淬�佹湀鍜屾棩 - return (calendarToCheck.get(Calendar.YEAR) == todayYear && calendarToCheck.get(Calendar.MONTH) == todayMonth && calendarToCheck.get(Calendar.DAY_OF_MONTH) == todayDay); + // 灏� Date 杞负 LocalDate + LocalDate localDate = date.toInstant().atZone(ZoneId.systemDefault()).toLocalDate(); + // 鑾峰彇浠婂ぉ鐨� LocalDate + LocalDate today = LocalDate.now(); + // 濡傛灉鏃ユ湡鏃╀簬鎴栫瓑浜庝粖澶╋紝杩斿洖 true + return !localDate.isAfter(today); } public void sfHandlle(CommonTaskcallMQ commonTaskcallMQ, String ip) { @@ -336,6 +335,15 @@ ivrTaskcall.setTaskid(commonTaskcallMQ.getTaskid()); ivrTaskcall.setSendstate(2L); List<ServiceSubtask> subtaskList = iServiceSubtaskService.selectServiceSubtaskList(ivrTaskcall); + //涓芥按鏈夌殑鍖婚櫌杩樻病娉曞仛闀挎湡浠诲姟闅忚 + List<ServiceSubtask> subtaskList2 = new ArrayList<>(); + if (visitHosp == 2) { + for (ServiceSubtask serviceSubtask : subtaskList) { + Boolean b = VisitSendStateEnum.getDescByCode(serviceSubtask.getOrgid()); + if (b) subtaskList2.add(serviceSubtask); + } + subtaskList = subtaskList2; + } // 鎸夌収 endtime 绂诲綋鍓嶆椂闂存渶杩戠殑鎺掑簭 List<ServiceSubtask> selectServiceSubtaskList = subtaskList.stream().sorted(Comparator.comparing(subtask -> Math.abs(subtask.getEndtime().getTime() - new Date().getTime()))).collect(Collectors.toList()); @@ -433,7 +441,8 @@ serviceSubtaskMapper.insertServiceSubtask(serviceSubtask); } } - } else if (descByCode.equals("鐭俊")) { + } + else if (descByCode.equals("鐭俊")) { RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample(); String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key); for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) { @@ -470,10 +479,36 @@ sendMagParam.setPhone(serviceSubtask.getPhone()); sendMagParam.setUrl(ip + ":" + req_path + "/wt?p=" + format); sendMagParam.setContent("銆愭柊鍗庡尰闄€�戞偍濂斤紝閭�璇锋偍濉啓鍑洪櫌璋冩煡琛紝璇风偣鍑�" + sendMagParam.getUrl() + "濉啓銆傛劅璋㈡偍閰嶅悎锛�"); - Map<String, String> req = new HashMap<>(); - req.put("phone", sendMagParam.getPhone()); - req.put("content", sendMagParam.getContent()); - String isSuccess = HttpUtil.postJsonRequest(xhsmsPath, new Gson().toJson(req)); + String isSuccess = null; + if (visitHosp == 1) { + Map<String, String> req = new HashMap<>(); + req.put("phone", sendMagParam.getPhone()); + req.put("content", sendMagParam.getContent()); + isSuccess = HttpUtil.postJsonRequest(xhsmsPath, new Gson().toJson(req)); + } else if (visitHosp == 2) { + //涓芥按鐨勭煭淇″彂閫佹柟寮� + Map<String, String> map = MsgLSEnum.getAddressByCode(serviceSubtask.getOrgid()); + String token = LSHospTokenUtil.getToken(serviceSubtask.getOrgid()); + if (ObjectUtils.isNotEmpty(map) && StringUtils.isEmpty(map.get("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("---------涓芥按鐭俊鍙戦�佸叆鍙俛ddress锛歿}, sendMagParam:{}, orgid:{}-------", map.get("address"), sendMagParam, serviceSubtask.getOrgid()); + String dxCode = getDXCode(map.get("address"), sendMagParam.getPhone(), sendMagParam.getContent(), map.get("sendPersonId"), map.get("sendPersonName"), 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")) { + isSuccess = "true"; + } + } //浠诲姟鍙戦�佽褰� ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord(); serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString()); @@ -509,13 +544,14 @@ } } } - } else if (descByCode.equals("鍏紬鍙�")) { + } + else if (descByCode.equals("鍏紬鍙�")) { log.error("鍏紬鍙疯繘鏉ヤ簡鍚楋紵{}", descByCode); //鍏紬鍙� RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample(); String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key); for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) { - log.error("serviceSubtask---------杩涙潵浜嗗悧锛焮}", serviceSubtask); + // log.error("serviceSubtask---------杩涙潵浜嗗悧锛焮}", serviceSubtask); boolean dateToday = isDateToday(serviceSubtask.getLongSendTime()); if (dateToday) { try { @@ -535,10 +571,32 @@ url = ip + ":" + req_path + "/outsideChainwt?param1=" + taskId + "¶m2=" + patid + "¶m3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "¶m5=false"; // String wxCode = getWXCode(serviceSubtask.getSfzh(), url, serviceSubtask.getTaskName(), serviceSubtask.getTaskDesc(), "鏃�"); - String wxCode = getWXCode(serviceSubtask.getSfzh(), url, serviceSubtask.getTaskName(), serviceSubtask.getTaskDesc(), patArchive.getTelcode(), serviceSubtask.getSendname(), patArchive.getPatientno()); + //鑾峰彇寰俊鍏紬鍙疯姹備俊鎭牴鎹満鏋処D + 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; + } + + 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; + } + String wxCode = getWXCode(serviceSubtask.getSfzh(), url, serviceSubtask.getTaskName(), serviceSubtask.getTaskDesc(), patArchive.getTelcode(), serviceSubtask.getSendname(), patArchive.getPatidHis(), wxqqxx); Map<String, Object> map = JSONObject.parseObject(wxCode, Map.class); - //浠诲姟鍙戦�佽褰� ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord(); serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString()); @@ -556,6 +614,7 @@ if ((Boolean) map.get("succ") == true) { serviceSubtask.setResult("success"); } else { + log.error("serviceSubtask1231313鐨勫�间负锛歿}", serviceSubtask); serviceSubtask.setResult("error"); serviceSubtask.setSendstate(5L); serviceSubtask.setRemark(map.get("msg").toString()); @@ -792,7 +851,38 @@ return key; } - private String getWXCode(String idcard, String url, String taskName, String taskDesc, String phone, String setPatientname, String setPatientid) { + 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; + } + + + private String getWXCode(String idcard, String url, String taskName, String taskDesc, String phone, String setPatientname, String setPatientid, List<String> wxqqxx) { XinHuaWXReq xinHuaWXReq = new XinHuaWXReq(); xinHuaWXReq.setIdcard(idcard); xinHuaWXReq.setUrl(url); @@ -802,17 +892,31 @@ xinHuaWXReq.setMedcardno(null); xinHuaWXReq.setTitlename(taskName); xinHuaWXReq.setContent(taskDesc); - xinHuaWXReq.setAppid(appid); + xinHuaWXReq.setAppid(wxqqxx.get(1)); log.error("----getWXCode---xinHuaWXReq鐨勫嚭鍙備负锛歿}", xinHuaWXReq); - String result = HttpUtils.sendPost(thirdWXUrl, new Gson().toJson(xinHuaWXReq)); + String body = new Gson().toJson(xinHuaWXReq); + String encode = encode(wxqqxx.get(2).concat(body)); + Map<String, String> headerMap = new HashMap<>(); + headerMap.put("sign", encode); + String result = HttpUtils.sendPostByHeader(wxqqxx.get(3), body, headerMap); + JSONObject jsonObject = JSONObject.parseObject(result); String code = (String) jsonObject.toString(); return code; } -// public static void main(String[] args) { -// LocalDateTime originalDateTime = LocalDateTime.now(); -// LocalDateTime startOfDay = originalDateTime.with(LocalTime.MIN); -// System.out.println("Original DateTime: " + originalDateTime); -// System.out.println("Start of Day: " + startOfDay); -// } + + + 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