From d940590c25d7381ba7bc08b068d223d7aa0b9c77 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期四, 30 四月 2026 20:43:12 +0800
Subject: [PATCH] 南华附一 和  登陆优化

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/common/SmsController.java |  144 +++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 118 insertions(+), 26 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 42758b8..115081f 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,33 +1,47 @@
 package com.ruoyi.web.controller.common;
 
-import com.ruoyi.common.config.RuoYiConfig;
+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.file.FileUtils;
 import com.ruoyi.common.utils.sms.smsUtils;
-import com.ruoyi.framework.config.ServerConfig;
-import com.smartor.domain.HtmlContentVO;
+import com.smartor.common.MtSubmitSmUtil;
+import com.smartor.domain.ServiceOutPath;
 import com.smartor.domain.smsVO;
+import com.smartor.mapper.UtilsMapper;
+import com.smartor.service.IServiceOutPathService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.ObjectUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
-import org.springframework.http.MediaType;
-import org.springframework.web.bind.annotation.*;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
 
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
 import java.io.UnsupportedEncodingException;
-import java.net.URLEncoder;
-import java.nio.charset.StandardCharsets;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
 
 @RestController
 @Api(description = "鐭ヤ俊鎺ュ彛")
 @RequestMapping("/sms")
+@Slf4j
 public class SmsController {
     @Value("${xhsmsPath}")
     private String xhsmsPath;
+
+    @Autowired
+    private MtSubmitSmUtil mtSubmitSmUtil;
 
     @Value("${xhsmsAccount}")
     private String xhsmsAccount;
@@ -44,6 +58,22 @@
     @Value("${pub_key}")
     private String pub_key;
 
+    @Autowired
+    private IServiceOutPathService iServiceOutPathService;
+
+    @Value("${spring.profiles.active}")
+    private String active;
+
+    /**
+     * @param
+     * @return
+     */
+    @ApiOperation("鐭俊鍙戦��")
+    @PostMapping("/sendTest")
+    public AjaxResult send(@RequestBody smsVO vo) {
+        String sendMsg = smsUtils.sendSms(xhsmsPath, xhsmsAccount, xhsmsPwd, vo.getPhone(), vo.getContent());
+        return AjaxResult.success(sendMsg);
+    }
 
     /**
      * @param
@@ -51,28 +81,90 @@
      */
     @ApiOperation("鐭俊鍙戦��")
     @PostMapping("/send")
-    public AjaxResult send(@RequestBody smsVO vo) {
-        String sendMsg=smsUtils.sendSms(xhsmsPath,xhsmsAccount,xhsmsPwd,vo.getPhone(),vo.getContent());
+    public AjaxResult sendAsk(@RequestBody smsVO vo) throws UnsupportedEncodingException {
+        String content = "";
+        if (StringUtils.isNotEmpty(vo.getTaskId()) && StringUtils.isNotEmpty(vo.getPatId()) && StringUtils.isNotEmpty(vo.getSubId())) {
+            RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
+            String taskId = rsaPublicKeyExample.encryptedData(vo.getTaskId().toString(), pub_key);
+            String patid = rsaPublicKeyExample.encryptedData(vo.getPatId().toString(), pub_key);
+            String subId = rsaPublicKeyExample.encryptedData(vo.getSubId().toString(), pub_key);
+            Integer radix = iServiceOutPathService.selectAutoId();
+            String format = String.format("%03X", radix);
+            ServiceOutPath serviceOutPath = new ServiceOutPath();
+            serviceOutPath.setParam1(taskId);
+            serviceOutPath.setParam2(patid);
+            serviceOutPath.setParam3(vo.getTaskName());
+            serviceOutPath.setParam6(subId);
+            serviceOutPath.setRadix(format);
+            serviceOutPath.setCreateTime(new Date());
+            iServiceOutPathService.insertServiceOutPath(serviceOutPath);
+            String url = ip + ":" + req_path + "/wt?p=" + format;
+            content = "鎮ㄥソ锛岄個璇锋偍濉啓鍑洪櫌璋冩煡琛紝璇风偣鍑�" + url + "濉啓銆傛劅璋㈡偍閰嶅悎锛�";
+        }
+
+        if (ObjectUtils.isNotEmpty(vo.getContent())) content = vo.getContent();
+
+        String sendMsg = "false";
+        try {
+            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());
+        }
         return AjaxResult.success(sendMsg);
     }
+
     /**
      * @param
      * @return
      */
-    @ApiOperation("鐭俊鍙戦��")
-    @PostMapping("/sendAsk")
-    public AjaxResult sendAsk(@RequestBody smsVO vo) throws UnsupportedEncodingException {
-//        String format = String.format("%03X", vo.getId());
-//        String url=ip + ":" + req_path + "/wt?p=" + format;
-        RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
-        String taskId = rsaPublicKeyExample.encryptedData(vo.getTaskId().toString(), pub_key);
-        String patid = rsaPublicKeyExample.encryptedData(vo.getPatId().toString(), pub_key);
-        String url = null;
-        url = ip + ":" + req_path + "/outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(vo.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
-
-        String content="鎮ㄥソ锛岄個璇锋偍濉啓鍑洪櫌璋冩煡琛紝璇风偣鍑�" + url + "濉啓銆傛劅璋㈡偍閰嶅悎锛�";
-
-        String sendMsg=smsUtils.sendSms(xhsmsPath,xhsmsAccount,xhsmsPwd,vo.getPhone(),content);
+    @ApiOperation("寰俊鍙戦��")
+    @PostMapping("/sendChat")
+    public AjaxResult sendChat(@RequestBody smsVO vo) throws UnsupportedEncodingException {
+        String sendMsg = "";
+        if (StringUtils.isNotEmpty(vo.getTaskId()) && StringUtils.isNotEmpty(vo.getPatId()) && StringUtils.isNotEmpty(vo.getSubId())) {
+            RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
+            String taskId = rsaPublicKeyExample.encryptedData(vo.getTaskId().toString(), pub_key);
+            String patid = rsaPublicKeyExample.encryptedData(vo.getPatId().toString(), pub_key);
+            String subId = rsaPublicKeyExample.encryptedData(vo.getSubId().toString(), pub_key);
+            Integer radix = iServiceOutPathService.selectAutoId();
+            String format = String.format("%03X", radix);
+            ServiceOutPath serviceOutPath = new ServiceOutPath();
+            serviceOutPath.setParam1(taskId);
+            serviceOutPath.setParam2(patid);
+            serviceOutPath.setParam3(vo.getTaskName());
+            serviceOutPath.setParam6(subId);
+            serviceOutPath.setRadix(format);
+            serviceOutPath.setCreateTime(new Date());
+            iServiceOutPathService.insertServiceOutPath(serviceOutPath);
+            String url = ip + ":" + req_path + "/wt?p=" + format;
+            sendMsg = smsUtils.sendChat(url, vo.getPhone(), vo.getIdCard());
+        }
         return AjaxResult.success(sendMsg);
     }
 }

--
Gitblit v1.9.3