天天看點

調用阿裡雲接口實作短信消息的發送源碼——CSDN部落格

在調用阿裡雲接口之前首先需要購買接口,獲得accessKeySecret,然後使用下列代碼就可以直接調用了!!

/**  
* @Title: TestPhoneVerification.java
* @Package org.test
* @Description: TODO該方法的主要作用:
* @author A18ccms A18ccms_gmail_com  
* @date 2017-7-1 下午8:19:35
* @version V1.0  
*/
package org.test;

import java.util.Random;

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.exceptions.ServerException;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;

 /**   
 *    
 * 項目名稱:facephoto2   
 * 類名稱:TestPhoneVerification   
 * 類描述:   
 * 建立人:Mu Xiongxiong  
 * 建立時間:2017-7-1 下午8:19:35   
 * 修改人:Mu Xiongxiong   
 * 修改時間:2017-7-1 下午8:19:35   
 * 修改備注:   
 * @version    
 *    
 */
public class TestPhoneVerification {
	public static void main(String[] args) throws ServerException, ClientException {
		
		// 設定逾時時間-可自行調整
		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産品域名
		// 替換成你的AK
		final String accessKeyId = "LTAIXhKAji7WzEFx";// 你的accessKeyId,參考本文檔步驟2
		final String accessKeySecret = "7mYMnzCGZ";// 你的accessKeySecret,參考本文檔步驟2
		// 初始化ascClient,暫時不支援多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();
		// 必填:待發送手機号。支援以逗号分隔的形式進行批量調用,批量上限為20個手機号碼,批量調用相對于單條調用及時性稍有延遲,驗證碼類型的短信推薦使用單條調用的方式
		request.setPhoneNumbers("15098932660");
		// 必填:短信簽名-可在短信控制台中找到
		request.setSignName("光明峰管理平台");
		// 必填:短信模闆-可在短信控制台中找到
		request.setTemplateCode("SMS_75720062");
		// 可選:模闆中的變量替換JSON串,如模闆内容為"親愛的${name},您的驗證碼為${code}"時,此處的值為
		int x = new Random().nextInt(1000000);
		request.setTemplateParam("{\"name\":\"張三\", \"number\":\"" + x + "\"}");
		// 可選:outId為提供給業務方擴充字段,最終在短信回執消息中将此值帶回給調用者
		// request.setOutId("yourOutId");
		// 請求失敗這裡會抛ClientException異常
		SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
		if (sendSmsResponse.getCode() != null
				&& sendSmsResponse.getCode().equals("OK")) {
			// 請求成功
			System.out.println("發送成功!");
		}else if(sendSmsResponse.getCode().equals("isv.BUSINESS_LIMIT_CONTROL")){
			System.out.println("此号碼頻繁發送驗證碼,暫時不能擷取!");
		}
		System.out.println(sendSmsResponse.getCode());
	}
}
           

繼續閱讀