阿里大魚傳送簡訊(工具類)
阿新 • • 發佈:2018-10-31
前言:需要去申請阿里大魚的賬號
點選跳轉阿里大魚平臺
1.座標
<!-- https://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-core -->
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version> 4.0.8</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-dysmsapi -->
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
< version>1.1.0</version>
</dependency>
2 .工具類(SmsUtil.java)
package com.czxy.util;
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.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
/**
* Created on 17/6/7.
* 簡訊API產品的DEMO程式,工程中包含了一個SmsDemo類,直接通過
* 執行main函式即可體驗簡訊產品API功能(只需要將AK替換成開通了雲通訊-簡訊產品功能的AK即可)
* 工程依賴了2個jar包(存放在工程的libs目錄下)
* 1:aliyun-java-sdk-core.jar
* 2:aliyun-java-sdk-dysmsapi.jar
*
* 備註:Demo工程編碼採用UTF-8
* 國際簡訊傳送請勿參照此DEMO
*/
public class SmsUtil {
//產品名稱:雲通訊簡訊API產品,開發者無需替換
static final String product = "Dysmsapi";
//產品域名,開發者無需替換
static final String domain = "dysmsapi.aliyuncs.com";
// TODO 此處需要替換成開發者自己的AK(在阿里雲訪問控制檯尋找)
static final String accessKeyId = "自己的申請的ak";
static final String accessKeySecret = "自己申請的ak";
public static SendSmsResponse sendSms(String mobile, String code) throws ClientException {
//可自助調整超時時間
System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("sun.net.client.defaultReadTimeout", "10000");
//初始化acsClient,暫不支援region化
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();
//必填:待發送手機號
request.setPhoneNumbers(mobile);
//必填:簡訊簽名-可在簡訊控制檯中找到
request.setSignName("簡訊簽名");
//必填:簡訊模板-可在簡訊控制檯中找到
request.setTemplateCode("簡訊模板");
//可選:模板中的變數替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為
request.setTemplateParam("{\"code\":"+code+"}");
//選填-上行簡訊擴充套件碼(無特殊需求使用者請忽略此欄位)
//request.setSmsUpExtendCode("90997");
//可選:outId為提供給業務方擴充套件欄位,最終在簡訊回執訊息中將此值帶回給呼叫者
request.setOutId("yourOutId");
//hint 此處可能會丟擲異常,注意catch
SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
return sendSmsResponse;
}
/*測試呼叫*/
public static void main(String[] args) {
try {
SmsUtil.sendSms("手機號","傳送內容");
} catch (ClientException e) {
e.printStackTrace();
}
}
}