From 3998703641edf236113f77f15c79561fd7f75c59 Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期五, 22 五月 2026 11:16:43 +0800
Subject: [PATCH] 【市一】短信发送

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/common/SmsController.java |   66 +++++++++++++++++++++++++++++++--
 1 files changed, 62 insertions(+), 4 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/common/SmsController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/common/SmsController.java
index eb55162..91ed52e 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/common/SmsController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/common/SmsController.java
@@ -1,10 +1,19 @@
 package com.ruoyi.web.controller.common;
 
+import com.fasterxml.jackson.databind.JsonNode;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.google.gson.Gson;
 import com.ruoyi.common.core.domain.AjaxResult;
+import com.ruoyi.common.dx.MessageSend;
+import com.ruoyi.common.utils.HttpUtil;
 import com.ruoyi.common.utils.RSAPublicKeyExample;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.sms.smsUtils;
+import com.smartor.common.MtSubmitSmUtil;
+import com.smartor.common.ShiyiSmsUtil;
 import com.smartor.domain.ServiceOutPath;
+import com.smartor.domain.ShiyiSmsRequest;
+import com.smartor.domain.ShiyiSmsResponse;
 import com.smartor.domain.smsVO;
 import com.smartor.mapper.UtilsMapper;
 import com.smartor.service.IServiceOutPathService;
@@ -20,7 +29,11 @@
 import org.springframework.web.bind.annotation.RestController;
 
 import java.io.UnsupportedEncodingException;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
 import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
 
 @RestController
 @Api(description = "鐭ヤ俊鎺ュ彛")
@@ -29,6 +42,12 @@
 public class SmsController {
     @Value("${xhsmsPath}")
     private String xhsmsPath;
+
+    @Autowired
+    private MtSubmitSmUtil mtSubmitSmUtil;
+
+    @Autowired
+    private ShiyiSmsUtil shiyiSmsUtil;
 
     @Value("${xhsmsAccount}")
     private String xhsmsAccount;
@@ -48,8 +67,8 @@
     @Autowired
     private IServiceOutPathService iServiceOutPathService;
 
-    @Autowired
-    private UtilsMapper utilsMapper;
+    @Value("${spring.profiles.active}")
+    private String active;
 
     /**
      * @param
@@ -60,6 +79,18 @@
     public AjaxResult send(@RequestBody smsVO vo) {
         String sendMsg = smsUtils.sendSms(xhsmsPath, xhsmsAccount, xhsmsPwd, vo.getPhone(), vo.getContent());
         return AjaxResult.success(sendMsg);
+    }
+
+    @ApiOperation("甯備竴HIS鐭俊XML娴嬭瘯")
+    @PostMapping("/sendShiyiTest")
+    public AjaxResult sendShiyiTest(@RequestBody ShiyiSmsRequest request) {
+        try {
+            ShiyiSmsResponse response = shiyiSmsUtil.sendSms(request);
+            return AjaxResult.success(response);
+        } catch (Exception e) {
+            log.error("甯備竴HIS鐭俊XML娴嬭瘯澶辫触", e);
+            return AjaxResult.error("甯備竴HIS鐭俊XML娴嬭瘯澶辫触: " + e.getMessage());
+        }
     }
 
     /**
@@ -91,9 +122,34 @@
 
         if (ObjectUtils.isNotEmpty(vo.getContent())) content = vo.getContent();
 
-        String sendMsg = "";
+        String sendMsg = "false";
         try {
-            sendMsg = smsUtils.sendSms(xhsmsPath, xhsmsAccount, xhsmsPwd, vo.getPhone(), content);
+            if (active.equals("hzszlyy")) {
+                sendMsg = smsUtils.sendSms(xhsmsPath, xhsmsAccount, xhsmsPwd, vo.getPhone(), content);
+            } else if (active.equals("nhfy")) {
+                Map<String, Object> smsResult = mtSubmitSmUtil.submitSm(vo.getPhone(), content);
+                if (smsResult != null && smsResult.get("result") != null && smsResult.get("result").toString().equals("0")) {
+                    sendMsg = "true";
+                }
+            } else if (active.equals("sltd")) {
+                String data = MessageSend.sendMsg(content, "6", vo.getPhone(), LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmss")));
+                if (StringUtils.isNotEmpty(data)) {
+                    ObjectMapper mapper = new ObjectMapper();
+                    JsonNode root = mapper.readTree(data);
+                    String status = root.get("result").get(0).get("status").asText();
+                    if (status.equals("00000")) {
+                        sendMsg = "true";
+                    }
+                }
+            } else if (active.equals("xh")) {
+                Map<String, String> req = new HashMap<>();
+                req.put("phone", vo.getPhone());
+                req.put("content", vo.getContent());
+                sendMsg = HttpUtil.postJsonRequest(xhsmsPath, new Gson().toJson(req));
+            } else if (active.equals("ls")) {
+                //涓芥按13瀹跺尰闄紝鏈夌偣涓嶆柟渚匡紝鏈夌┖鍐嶆帴
+                return AjaxResult.error("璇ョ煭淇″姛鑳借繕鏈紑閫�");
+            }
             log.info(sendMsg);
         } catch (Exception ex) {
             log.error(ex.getMessage());
@@ -129,4 +185,6 @@
         }
         return AjaxResult.success(sendMsg);
     }
+
+
 }

--
Gitblit v1.9.3