1. 程式人生 > 其它 >阿里雲簡訊傳送

阿里雲簡訊傳送

<!--簡訊傳送-->
<dependency>
	<groupId>com.aliyun</groupId>
	<artifactId>aliyun-java-sdk-core</artifactId>
	<version>4.5.25</version>
</dependency>
<dependency>
	<groupId>com.aliyun</groupId>
	<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
	<version>2.0.0</version>
</dependency>
<dependency>
	<groupId>com.google.code.gson</groupId>
	<artifactId>gson</artifactId>
	<version>2.8.8</version>
</dependency>
public class SendPhoneMessageUtils {
	//
    private static final String ACCESSKEY_ID = "你的祕鑰鍵";
	//
    private static final String ACCESS_KEY_SECRET = "你的祕鑰值";
	//
    private static final String SIGN_NAME = "簡訊簽名";
	//
    private static final String TEMPLATE_CODE = "簡訊模板";//您的註冊碼:${code},如非本人操作,請忽略本簡訊!


    /*public static void main(String[] args) throws Exception {
        sendMessage("123456", "18438860920");
    }*/

    /**
     * @param codeValue   簡訊驗證碼
     * @param phoneNumber 手機號
     */
    public static void sendMessage(String codeValue, String phoneNumber) {
        // 設定超時時間-可自行調整
        System.setProperty("sun.net.client.defaultConnectTimeout", "20000");
        System.setProperty("sun.net.client.defaultReadTimeout", "20000");
        // 初始化ascClient需要的幾個引數
        final String product = "Dysmsapi";// 簡訊API產品名稱(簡訊產品名固定,無需修改)
        final String domain = "dysmsapi.aliyuncs.com";// 簡訊API產品域名(介面地址固定,無需修改)
        // 初始化ascClient,暫時不支援多region(請勿修改)
        IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", ACCESSKEY_ID, ACCESS_KEY_SECRET);

        try {
            DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
            IAcsClient acsClient = new DefaultAcsClient(profile);
            // 組裝請求物件
            SendSmsRequest request = new SendSmsRequest();
            // 使用post提交
            request.setMethod(MethodType.POST);
            // 必填:待發送手機號。支援以逗號分隔的形式進行批量呼叫,批量上限為1000個手機號碼,批量呼叫相對於單條呼叫及時性稍有延遲,驗證碼型別的簡訊推薦使用單條呼叫的方式;傳送國際/港澳臺訊息時,接收號碼格式為國際區號+號碼,如“85200000000”
            request.setPhoneNumbers(phoneNumber);
            // 必填:簡訊簽名-可在簡訊控制檯中找到
            request.setSignName(SIGN_NAME);
            // 必填:簡訊模板-可在簡訊控制檯中找到,傳送國際/港澳臺訊息時,請使用國際/港澳臺簡訊模版
            request.setTemplateCode(TEMPLATE_CODE);
            // 可選:模板中的變數替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為
            // 友情提示:如果JSON中需要帶換行符,請參照標準的JSON協議對換行符的要求,比如簡訊內容中包含\r\n的情況在JSON中需要表示成\\r\\n,否則會導致JSON在服務端解析失敗
            request.setTemplateParam("{\"code\":\"" + codeValue + "\"}");
            // 可選-上行簡訊擴充套件碼(擴充套件碼欄位控制在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 {
                throw new RuntimeException("驗證碼傳送失敗!");
            }
        } catch (Exception e) {
            throw new RuntimeException("驗證碼傳送失敗!");
        }
    }
}