使用阿里雲的簡訊介面
阿新 • • 發佈:2019-01-23
需要匯入兩個架包 :aliyun-java-sdk-core-3.2.8.jar
aliyun-java-sdk-dysmsapi-1.0.0.jar
登入阿里雲賬號
建立 Access Key 獲取 Access Key ID和 Access Key Secret
建立符合自身屬性的簽名信息 簡訊簽名需要稽核通過後才可以使用。
建立簡訊模板,即具體傳送的簡訊內容。 簡訊模板需要稽核通過後才可以使用
簡訊模板可以支援驗證碼、簡訊通知、推廣簡訊三種模式。
package com.note.demo;
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.exceptions.ClientException;
import com.aliyuncs.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
/**
* 使用阿里雲簡訊介面
* @author HYP
*
*/
public class MoblieMessageUtil {
public static void main(String[] args) throws ClientException { //設定超時時間-可自行調整 System.setProperty("sun.net.client.defaultConnectTimeout", "10000"); System.setProperty("sun.net.client.defaultReadTimeout", "10000"); //初始化ascClient需要的幾個引數 final String product = "Dysmsapi";//簡訊API產品名稱(簡訊產品名固定,無需修改) final String domain = "dysmsapi.aliyuncs.com";//簡訊API產品域名(介面地址固定,無需修改) //替換成你的AK final String accessKeyId = "yourAccessKeyId"; final String accessKeySecret = "accessKeySecret";//你的accessKeySecret, IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId,accessKeySecret); 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("18530081124"); //必填:簡訊簽名-可在簡訊控制檯中找到----就是簽名名稱 request.setSignName("簽名名稱"); //必填:簡訊模板-可在簡訊控制檯中找到 例如:SMS_127156997 request.setTemplateCode("模版CODE"); //可選:模板中的變數替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為 //友情提示:如果JSON中需要帶換行符,請參照標準的JSON協議對換行符的要求,比如簡訊內容中包含\r\n的情況在JSON中需要表示成\\r\\n,否則會導致JSON在服務端解析失敗 /*模版內容: 尊敬的使用者,您的驗證密碼為:${code},請勿洩漏於他人! 傳送人:java開發工程師*/ request.setTemplateParam("{\"code\":\"177659\"}"); //可選-上行簡訊擴充套件碼(擴充套件碼欄位控制在7位或以下,無特殊需求使用者請忽略此欄位) //request.setSmsUpExtendCode("90997"); //可選:outId為提供給業務方擴充套件欄位,最終在簡訊回執訊息中將此值帶回給呼叫者 request.setOutId("yourOutId"); //請求失敗這裡會拋ClientException異常 SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request); if(sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) { //請求成功 System.out.println("簡訊傳送成功請查收"); }else { System.out.println("傳送簡訊失敗"); } }
}