java實現發短信功能---騰訊雲短信


java實現發短信功能

前言

如今發短信功能已經成為互聯網公司的標配,本篇文章將一步步實現java發送短信

考察了許多提供短信服務的三方,幾乎所有都需要企業認證才可以使用,這對於個人學習非常不方便。多方比較之后,選擇了騰訊雲(此處並非做廣告),原因有兩點:

  1. 支持微信公眾號認證(門檻低)
  2. 每月贈送100條免費短信(適合個人學習)(這一點請礦家子弟自行忽略)

免費短信

開發環境

請參照: 基於SpringBoot構建分模塊項目

騰訊雲 ---短信

  1. 找到短信服務

    短信服務

  2. 開通之后,點擊添加應用

    添加應用

  3. 設置短信簽名(以公眾號為例),簽名類型選擇公眾號或小程序,其余按照要求填寫即可

    設置簽名

  4. 簽名完成之后,創建短信模板

    創建模板

  5. 等待以上信息審核完成之后,便可以開始使用了,騰訊短信服務需要用到SDK AppID 和App Key ,在這里:

    公鑰私鑰

代碼

  1. pom.xml引入依賴

    <properties>
        <java.version>1.8</java.version>
        <!-- 你的其他依賴。。。 -->
        <tencent.qcloudsms.version>1.0.6</tencent.qcloudsms.version>
    </properties>
    
    <dependencies>
        <!-- 你的其他依賴。。。 -->
        <!-- 騰訊短信 -->
        <dependency>
            <groupId>com.github.qcloudsms</groupId>
            <artifactId>qcloudsms</artifactId>
            <version>${tencent.qcloudsms.version}</version>
        </dependency>
    </dependencies>
    
  2. 發送短信工具類

    package com.wayne.common.utils;
    
    import com.github.qcloudsms.*;
    import com.github.qcloudsms.httpclient.HTTPException;
    import com.wayne.common.entity.CmsMessageConfig;
    import com.wayne.common.exception.CustomException;
    import com.wayne.common.form.MessageForm;
    import org.json.JSONException;
    
    import java.io.IOException;
    
    /**
     * 發送短信工具類
     * @author Wayne
     * @date 2019/6/26
     */
    public class MessageUtils {
    
        /**
         * 按模板發送短信 支持單發和群發
         * @param isSingle 是否單發 true: 單發,false: 群發
         * @param form 需要發送的短信內容及收信人手機號
         * @param config 短信配置
         * @throws CustomException 發送失敗時捕獲的異常信息
         */
        public static void sendMessage(Boolean isSingle, MessageForm form, CmsMessageConfig config) throws CustomException {
            validateMessage(form, config);
            String regex = ";";
            String[] params = {form.getCaptcha()};
            String[] phoneNumbers = form.getMobiles().split(regex);
    
            SmsResultBase result;
    
            try {
                // 是否單發
                if (isSingle) {
                    SmsSingleSender ssender = new SmsSingleSender(config.getAppId(), config.getAppKey());
                    result = ssender.sendWithParam("86", phoneNumbers[0], config.getTemplateId(), params, config.getSmsSign(), "", "");
                } else {
                    SmsMultiSender msender = new SmsMultiSender(config.getAppId(), config.getAppKey());
                    result =  msender.sendWithParam("86", phoneNumbers, config.getTemplateId(), params, config.getSmsSign(), "", "");
                }
                System.out.println(result);
            } catch (HTTPException e) {
                e.printStackTrace();
                throw new CustomException("HTTP響應碼錯誤");
            } catch (JSONException e) {
                e.printStackTrace();
                throw new CustomException("json解析錯誤");
            } catch (IOException e) {
                e.printStackTrace();
                throw new CustomException("網絡IO錯誤");
            }
        }
    
        /**
         * 校驗參數
         */
        private static void validateMessage(MessageForm messageForm, CmsMessageConfig messageConfig) throws CustomException {
            ValidatorUtils.validateEntity(messageForm);
            if (null == messageConfig) {
                throw new CustomException("系統參數異常");
            }
        }
    }
    
  3. CmsMessageConfig配置類

       package com.wayne.common.entity;
       
       import lombok.Data;
       
       import javax.persistence.*;
       
       @Data
       @Table(name = "cms_message_config")
       public class CmsMessageConfig {
           /**
            * 主鍵
            */
           @Id
           @Column(name = "ID")
           private Integer id;
       
           /**
            * AppID
            */
           @Column(name = "APP_ID")
           private Integer appId;
       
           /**
            * AppKey
            */
           @Column(name = "APP_KEY")
           private String appKey;
       
           /**
            * 短信模板ID
            */
           @Column(name = "TEMPLATE_ID")
           private Integer templateId;
       
           /**
            * 簽名內容
            */
           @Column(name = "SMS_SIGN")
           private String smsSign;
       
           /**
            * 是否刪除,0:否,1:是
            */
           @Column(name = "IS_DELETE")
           private String isDelete;
       
           /**
            * 狀態,0:使用,1:未使用 (同一時間應最多只有一條數據處於使用狀態)
            */
           @Column(name = "IS_USE")
           private String isUse;
       
           /**
            * 創建者ID
            */
           @Column(name = "CREATE_ADMIN_ID")
           private Integer createAdminId;
       
           @Column(name = "EXTEND1")
           private String extend1;
       
           @Column(name = "EXTEND2")
           private String extend2;
       
           @Column(name = "EXTEND3")
           private String extend3;
       
           @Column(name = "EXTEND4")
           private String extend4;
       
           @Column(name = "EXTEND5")
           private String extend5;
       
           @Column(name = "EXTEND6")
           private String extend6;
       }
    
  4. Service

       @Override
       public ResponseBean sendMessage(MessageForm messageForm) {
           ValidatorUtils.validateEntity(messageForm);
       
           // 獲取正在使用的短信配置: 此處為 從數據庫中查詢
           CmsMessageConfig messageConfig = getCurrUseMessageConfig();
       
           try {
               // 發送短信
               MessageUtils.sendMessage(Boolean.FALSE, messageForm, messageConfig);
           } catch (CustomException e) {
               e.printStackTrace();
               return ResponseBean.createInstance(Boolean.FALSE, 401, e.getMessage());
           }
       
           return ResponseBean.createInstance();
       }
    
  5. Controller

       @PostMapping("/message/sendMessage")
       public ResponseBean sendMessage(MessageForm messageForm) {
           return messageService.sendMessage(messageForm);
       }
    

效果

  1. 一號短信模板模板一

  2. 二號短信模板

    模板二

  3. 設置短信配置信息

    配置

結束語

最后,本人已開通公眾號,歡迎大家前來灌水

公眾號


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM