1. 程式人生 > >阿里大魚傳送簡訊(工具類)

阿里大魚傳送簡訊(工具類)

前言:需要去申請阿里大魚的賬號
點選跳轉阿里大魚平臺

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(); } } }