From bedd0a1cef215538df64470df6b8d4a022189136 Mon Sep 17 00:00:00 2001 From: liusheng <337615773@qq.com> Date: 星期三, 28 八月 2024 14:05:16 +0800 Subject: [PATCH] 代码提交 --- smartor/src/main/java/com/smartor/common/SendService.java | 107 ++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 89 insertions(+), 18 deletions(-) diff --git a/smartor/src/main/java/com/smartor/common/SendService.java b/smartor/src/main/java/com/smartor/common/SendService.java index 7645456..4a40d8b 100644 --- a/smartor/src/main/java/com/smartor/common/SendService.java +++ b/smartor/src/main/java/com/smartor/common/SendService.java @@ -1,17 +1,31 @@ package com.smartor.common; +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONObject; import com.aliyun.dysmsapi20170525.models.SendSmsResponseBody; -import com.smartor.domain.BaseSmsRequest; -import com.smartor.domain.DingTalkReqVo; -import com.smartor.domain.SendMagParam; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.ruoyi.common.utils.http.HttpUtils; +import com.smartor.domain.*; +import com.smartor.mapper.PatWildcardMapper; import com.smartor.service.DingTalkService; +import com.smartor.service.ISmsParamService; +import com.smartor.service.WeChatService; import com.smartor.service.impl.BaseSmsaccountServiceImpl; +import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; + +import java.lang.reflect.Field; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.UUID; /** * 鍙戦�佹湇鍔″伐鍏风被 */ +@Slf4j @Component public class SendService { @Autowired @@ -20,33 +34,65 @@ @Autowired private DingTalkService dingTalkService; + @Autowired + private PatWildcardMapper patWildcardMapper; + + @Autowired + private WeChatService weChatService; + + @Autowired + ISmsParamService iSmsParamService; + public Boolean sendMsg(SendMagParam sendMagParam) { + // 1,澶氬獟浣� 2,绾歌川 3,鐢佃瘽 4,鐭俊 5.寰俊鍏紬鍙� 6.寰俊灏忕▼搴� 7.鏀粯瀹� 8.鏅鸿兘灏忕▼搴� 9.閽夐拤 switch (sendMagParam.getType()) { - case ("澶氬獟浣�"): + case ("1"): - case ("绾歌川"): + case ("2"): - case ("鐢佃瘽"): + case ("3"): - case ("鐭俊"): - BaseSmsRequest baseSmsRequest = new BaseSmsRequest(); - baseSmsRequest.setPhoneNumber(sendMagParam.getPhone()); - baseSmsRequest.setTemplateCode("SMS_461860582"); - - SendSmsResponseBody sendSmsResponseBody = baseSmsaccountService.sendMsg(baseSmsRequest); - if (sendSmsResponseBody.getCode().equals("OK")) { + case ("4"): + //鐭俊 + int i = iSmsParamService.sendSmsInfo(sendMagParam.getUrl(), sendMagParam.getPhone()); + if (i == 1) { return true; } + return false; - case ("寰俊鍏紬鍙�"): + case ("5"): + //鍏紬鍙� +// String params = "service=smarthos.yygh.ApiService.push&idcard=" + sendMagParam.getIdcard() + "&url=" + sendMagParam.getUrl() + "&keyword1=null&keyword2=null&keyword3=null&keyword4=null"; +// String result = HttpUtils.sendPost("/api", params); +// JSONObject jsonObject = JSONObject.parseObject(result); +// String code = (String) jsonObject.get("code"); +// if (!code.equals(0)) { +// log.error("寰俊鍏紬鍙锋秷鎭彂閫佸け璐ヤ簡锛歿}", sendMagParam); +// return false; +// } +// return true; - case ("寰俊灏忕▼搴�"): + WeChatSendVo weChatSendVo = new WeChatSendVo(); + weChatSendVo.setUrl(sendMagParam.getUrl()); + weChatSendVo.setTemplateId(sendMagParam.getTmpCode()); + ObjectMapper objectMapper = new ObjectMapper(); + Map map = null; + try { + map = objectMapper.readValue(sendMagParam.getContent(), Map.class); + } catch (JsonProcessingException e) { + e.printStackTrace(); + } + weChatSendVo.setContent(map); + weChatSendVo.setOpenid(sendMagParam.getOpenid()); + Boolean aBoolean1 = weChatService.sendMessageToFollowers(weChatSendVo); + return aBoolean1; + case ("6"): - case ("鏀粯瀹�"): + case ("7"): - case ("鏅鸿兘灏忕▼搴�"): + case ("8"): - case ("閽夐拤"): + case ("9"): DingTalkReqVo dingTalkReqVo = new DingTalkReqVo(); Boolean aBoolean = dingTalkService.sendNotification(dingTalkReqVo); if (aBoolean) { @@ -57,4 +103,29 @@ } } + + /** + * 瀵归棶棰樹腑鐨勯�氶厤绗﹁繘琛屽尮閰� + * + * @param script + * @param patArchive + * @return + */ + public String patWildcard(String script, PatArchive patArchive) { + List<PatWildcard> patWildcards = patWildcardMapper.selectPatWildcardList(new PatWildcard()); + for (PatWildcard patWildcard : patWildcards) { + try { + //鑾峰彇鎮h�呭搴旂殑瀛楁鐨勫�� + Field field = patArchive.getClass().getField(patWildcard.getPatField()); + field.setAccessible(true); + String value = field.get(patArchive).toString(); + //灏嗛棶棰樹腑鐨勯�氶厤绗﹁繘琛屾浛鎹� + script.replaceAll(patWildcard.getWildcard(), value); + } catch (Exception e) { + e.printStackTrace(); + } + } + + return script; + } } -- Gitblit v1.9.3