From c76bbf920f7ea32d2c604cdc529b865950ea24ac Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期四, 21 八月 2025 15:28:14 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 server/services/src/main/java/com/doumee/service/business/AliSmsService.java |  180 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 180 insertions(+), 0 deletions(-)

diff --git a/server/services/src/main/java/com/doumee/service/business/AliSmsService.java b/server/services/src/main/java/com/doumee/service/business/AliSmsService.java
new file mode 100644
index 0000000..71625fb
--- /dev/null
+++ b/server/services/src/main/java/com/doumee/service/business/AliSmsService.java
@@ -0,0 +1,180 @@
+package com.doumee.service.business;
+
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.aliyuncs.DefaultAcsClient;
+import com.aliyuncs.IAcsClient;
+import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
+import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
+import com.aliyuncs.http.MethodType;
+import com.aliyuncs.profile.DefaultProfile;
+import com.aliyuncs.profile.IClientProfile;
+import com.doumee.core.constants.Constants;
+import com.doumee.core.utils.DateUtil;
+import com.doumee.dao.business.CategoryMapper;
+import com.doumee.dao.business.model.Category;
+import com.doumee.dao.business.model.IdentityInfo;
+import com.doumee.dao.business.model.Orders;
+import com.doumee.dao.dto.CateringDTO;
+import com.github.pagehelper.Constant;
+import com.github.xiaoymin.knife4j.core.util.CollectionUtils;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.math.BigDecimal;
+import java.util.*;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2025/7/23 11:37
+ */
+@Service
+@Slf4j
+public class AliSmsService {
+
+    protected Logger logger = LogManager.getLogger("sms");
+
+    private final static String ACCESS_KEY_ID = "LTAI5tMkg7wwV74a8H6Bm3Ej";
+    private final static String ACCESS_KEY_SECRET = "FcHKST36sfwfo706L6bvrweGFIbp3n";
+    private final static String SING_NAME = "姗欐澶╀笅绉戞妧";
+
+
+    public void sendSms(int type, String phone, Orders orders, String receiveName, String businessPhone, BigDecimal distance, IdentityInfo identityInfo,CategoryMapper categoryMapper){
+        Constants.smsContent smsContent = Constants.smsContent.getSmsContent(type);
+        Map<String,Object> tempParam = new HashMap<>();
+        if(smsContent.getName().indexOf("time1")>=Constants.ZERO){
+            tempParam.put("time1", DateUtil.formatDate(orders.getStartDate(),"MM-dd"));
+        }
+        if(smsContent.getName().indexOf("time2")>=Constants.ZERO){
+            tempParam.put("time2", DateUtil.formatDate(orders.getEndDate(),"MM-dd"));
+        }
+        if(smsContent.getName().indexOf("name")>=Constants.ZERO){
+            tempParam.put("name", receiveName);
+        }
+        if(smsContent.getName().indexOf("money")>=Constants.ZERO){
+            tempParam.put("money", new BigDecimal(orders.getReceiveAccount().toString()).divide(new BigDecimal("100"),2,BigDecimal.ROUND_HALF_UP)+"鍏�");
+        }
+        if(smsContent.getName().indexOf("distance")>=Constants.ZERO){
+            tempParam.put("distance", distance +"km");
+        }
+        //璁よ瘉鐭俊 鐗规畩澶勭悊
+        if(Constants.equalsInteger(smsContent.getKey(),Constants.smsContent.authentication.getKey())){
+            //璁よ瘉绫诲瀷
+            if(smsContent.getName().indexOf("authentication")>=Constants.ZERO){
+                tempParam.put("authentication", Constants.equalsInteger(identityInfo.getAuthType(),Constants.ZERO)?"涓汉":identityInfo.getCompanyName());
+            }
+            if(smsContent.getName().indexOf("order")>=Constants.ZERO){
+                tempParam.put("order", Constants.orderType.getName(identityInfo.getType()).replace("鍗�",""));
+            }
+            if(smsContent.getName().indexOf("status")>=Constants.ZERO){
+                tempParam.put("status", Constants.equalsInteger(identityInfo.getAuditStatus(),Constants.TWO)?"宸查�氳繃":"鏈�氳繃");
+            }
+        }else{
+            if(smsContent.getName().indexOf("order")>=Constants.ZERO){
+                String order = "";
+                //鏌ヨ璁㈠崟鐨勭被鍨嬩俊鎭�
+                if(Constants.equalsInteger(orders.getType(),Constants.ZERO)){
+                    order = Constants.workType.getName(orders.getWorkType());
+                    Category category = categoryMapper.selectById(orders.getCategoryId());
+                    if(Objects.nonNull(category)){
+                        order = category.getName() + order;
+                    }
+                }else if(Constants.equalsInteger(orders.getType(),Constants.ZERO)){
+                    order = "杩愯緭";
+                    Category category = categoryMapper.selectById(orders.getTransportTypeId());
+                    if(Objects.nonNull(category)){
+                        order = category.getName() + order;
+                    }
+                }else{
+                    List<CateringDTO> cateringDTOList = JSONArray.parseArray(orders.getWayInfo(),CateringDTO.class);
+                    if(CollectionUtils.isNotEmpty(cateringDTOList)){
+                        for (CateringDTO cateringDTO:cateringDTOList) {
+                            if(StringUtils.isBlank(order)){
+                                order = cateringDTO.getName();
+                            }else{
+                                order = order + "/" +cateringDTO.getName();
+                            }
+                        }
+                    }
+                }
+                tempParam.put("order",order);
+            }
+        }
+
+        if(smsContent.getName().indexOf("authentication")>=Constants.ZERO){
+            tempParam.put("distance", distance +"km");
+        }
+        AliSmsService.sendSms(phone,smsContent.getCode(), JSONObject.toJSONString(tempParam));
+    }
+
+
+    public static void main(String[] args) {
+        Map<String,Object> tempParam = new HashMap<>();
+        tempParam.put("order","钁¤悇閲囨憳宸�");
+        tempParam.put("time1","07-23");
+        tempParam.put("time2","07-24");
+        AliSmsService.sendSms("18055151023","SMS_491055243", JSONObject.toJSONString(tempParam));
+    }
+
+
+    /**
+     * 鍙戠煭淇℃ā鏉�(鍙兢鍙�)
+     *
+     * @param phone         璁㈠崟璇︽儏
+     * @param templateCode  妯℃澘code
+     * @param templateParam 妯℃澘鍙橀噺json瀛楃涓�
+     * @return 澶勭悊缁撴灉
+     */
+    public static Boolean sendSms(String phone, String templateCode, String templateParam) {
+        try {
+            //璁剧疆瓒呮椂鏃堕棿-鍙嚜琛岃皟鏁�
+            System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
+            System.setProperty("sun.net.client.defaultReadTimeout", "10000");
+            //鍒濆鍖朼scClient闇�瑕佺殑鍑犱釜鍙傛暟
+            //鐭俊API浜у搧鍚嶇О锛堢煭淇′骇鍝佸悕鍥哄畾锛屾棤闇�淇敼锛�
+            final String product = "Dysmsapi";
+            //鐭俊API浜у搧鍩熷悕锛堟帴鍙e湴鍧�鍥哄畾锛屾棤闇�淇敼锛�
+            final String domain = "dysmsapi.aliyuncs.com";
+            //鍒濆鍖朼scClient,鏆傛椂涓嶆敮鎸佸region锛堣鍕夸慨鏀癸級
+            IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", ACCESS_KEY_ID, ACCESS_KEY_SECRET);
+            DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
+            IAcsClient acsClient = new DefaultAcsClient(profile);
+            //缁勮璇锋眰瀵硅薄
+            SendSmsRequest request = new SendSmsRequest();
+            //浣跨敤post鎻愪氦
+            request.setMethod(MethodType.POST);
+            //蹇呭~:寰呭彂閫佹墜鏈哄彿銆傛敮鎸佷互閫楀彿鍒嗛殧鐨勫舰寮忚繘琛屾壒閲忚皟鐢紝鎵归噺涓婇檺涓�1000涓墜鏈哄彿鐮�,鎵归噺璋冪敤鐩稿浜庡崟鏉¤皟鐢ㄥ強鏃舵�х◢鏈夊欢杩�,楠岃瘉鐮佺被鍨嬬殑鐭俊鎺ㄨ崘浣跨敤鍗曟潯璋冪敤鐨勬柟寮�
+            request.setPhoneNumbers(phone);
+            //蹇呭~:鐭俊绛惧悕-鍙湪鐭俊鎺у埗鍙颁腑鎵惧埌
+            request.setSignName(SING_NAME);
+            //蹇呭~:鐭俊妯℃澘-鍙湪鐭俊鎺у埗鍙颁腑鎵惧埌
+            request.setTemplateCode(templateCode);
+            //鍙��:妯℃澘涓殑鍙橀噺鏇挎崲JSON涓�,濡傛ā鏉垮唴瀹逛负"浜茬埍鐨�${name},鎮ㄧ殑楠岃瘉鐮佷负${code}"鏃�,姝ゅ鐨勫�间负
+            //鍙嬫儏鎻愮ず:濡傛灉JSON涓渶瑕佸甫鎹㈣绗�,璇峰弬鐓ф爣鍑嗙殑JSON鍗忚瀵规崲琛岀鐨勮姹�,姣斿鐭俊鍐呭涓寘鍚玕r\n鐨勬儏鍐靛湪JSON涓渶瑕佽〃绀烘垚\\r\\n,鍚﹀垯浼氬鑷碕SON鍦ㄦ湇鍔$瑙f瀽澶辫触
+            request.setTemplateParam(templateParam);
+            //鍙��-涓婅鐭俊鎵╁睍鐮�(鎵╁睍鐮佸瓧娈垫帶鍒跺湪7浣嶆垨浠ヤ笅锛屾棤鐗规畩闇�姹傜敤鎴疯蹇界暐姝ゅ瓧娈�)
+            //dto.setSmsUpExtendCode("90997");
+            //鍙��:outId涓烘彁渚涚粰涓氬姟鏂规墿灞曞瓧娈�,鏈�缁堝湪鐭俊鍥炴墽娑堟伅涓皢姝ゅ�煎甫鍥炵粰璋冪敤鑰�
+            //dto.setOutId("yourOutId");
+            //璇锋眰澶辫触杩欓噷浼氭姏ClientException寮傚父
+            SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
+            if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
+//                logger.info(phone + "-" + templateCode + "-" + templateParam + " >>> " + JSON.toJSONString(sendSmsResponse));
+                return true;
+            } else {
+//                logger.error(phone + "-" + templateCode + "-" + templateParam + " >>> " + JSON.toJSONString(sendSmsResponse));
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+//            logger.error(e);
+        }
+        return false;
+    }
+}

--
Gitblit v1.9.3