随着網際網路的興起,各行各業的需求都在不斷的增加。随着業務的擴大,企業給使用者發送短信驗證碼的業務,也是如火如荼。在這裡,calvin給各位開發者推薦阿裡雲短信平台。原因有二:1.接入較簡單,開發成本低 2.非常穩定,短信可達率99%。
OK,那麼接下來我們就可以開發阿裡短信接口吧。主要包括兩個步驟,第一個是前期準備,包括注冊阿裡雲賬号,獲得access_key和access_secret,并且申請短信簽名和短信模闆。第二個步驟則是引入阿裡短信服務的SDK,并正式開發。
一、前期準備
1.注冊阿裡雲賬号
進入網址 https://www.aliyun.com/ 點選免費注冊,輸入相關資訊,則成為阿裡雲使用者。
2.擷取Access_key和Access_secret
3.簽名管理與模闆管理
首先點選産品與服務,選擇短信服務。
我們需要關心的是應用開發這塊。
分别申請簽名管理和模闆管理。
注意,如果是個人學習使用,盡量
二、開發步驟
前面的準備工作都做完并且都申請通過後,我們可以正式進入我們的開發工作。
可以先在IDEA中建立一個Maven工程。通過依賴阿裡短信服務的SDK或者在pom檔案中添加相關依賴。
SDK及Demo下載下傳位址為:
https://help.aliyun.com/document_detail/101874.html?source=5176.11533457&type=copy
這裡建議使用在pom檔案中添加相關依賴,這樣比較友善。
<dependencies>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>3.7.1</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
<version>1.1.0</version>
</dependency>
</dependencies>
了解一下入參與出參
根據官方給出的demo,我們建立類AliDayunSms,在主方法中寫入發送短信驗證碼的邏輯。代碼如下:
1 import com.aliyuncs.DefaultAcsClient;
2 import com.aliyuncs.IAcsClient;
3 import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
4 import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
5 import com.aliyuncs.exceptions.ClientException;
6 import com.aliyuncs.http.MethodType;
7 import com.aliyuncs.profile.DefaultProfile;
8 import com.aliyuncs.profile.IClientProfile;
9
10
11 public class AliDayunSms {
12
13 public static void main(String[] args) throws ClientException {
14 //設定逾時時間-可自行調整
15 System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
16 System.setProperty("sun.net.client.defaultReadTimeout", "10000");
17 //初始化ascClient需要的幾個參數
18 final String product = "Dysmsapi";//短信API産品名稱(短信産品名固定,無需修改)
19 final String domain = "dysmsapi.aliyuncs.com";//短信API産品域名(接口位址固定,無需修改)
20 //替換成你的AK
21 final String accessKeyId = "your accessKeyId";//你的accessKeyId
22 final String accessKeySecret = "your accessKeySecret";//你的accessKeySecret
23 //初始化ascClient,暫時不支援多region(請勿修改)
24 IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret);
25 DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
26 IAcsClient acsClient = new DefaultAcsClient(profile);
27 //組裝請求對象
28 SendSmsRequest request = new SendSmsRequest();
29 //使用post送出
30 request.setMethod(MethodType.POST);
31 //必填:待發送手機号。支援以逗号分隔的形式進行批量調用,批量上限為1000個手機号碼,批量調用相對于單條調用及時性稍有延遲,驗證碼類型的短信推薦使用單條調用的方式;發送國際/港澳台消息時,接收号碼格式為00+國際區号+号碼,如“0085200000000”
32 request.setPhoneNumbers("your phoneNumber");
33 //必填:短信簽名-可在短信控制台中找到
34 request.setSignName("your signName");
35 //必填:短信模闆-可在短信控制台中找到,發送國際/港澳台消息時,請使用國際/港澳台短信模版
36 request.setTemplateCode("your templateCode");
37 //可選:模闆中的變量替換JSON串,如模闆内容為"親愛的${name},您的驗證碼為${code}"時,此處的值為
38 //友情提示:如果JSON中需要帶換行符,請參照标準的JSON協定對換行符的要求,比如短信内容中包含\r\n的情況在JSON中需要表示成\\r\\n,否則會導緻JSON在服務端解析失敗
39 //request.setTemplateParam("{\"code\":\"988756\"}");
40 String msgCode = getMsgCode();
41 request.setTemplateParam("{\"code\":\"" + msgCode + "\"}");
42 //請求失敗這裡會抛ClientException異常
43 SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
44 if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
45 //請求成功
46 System.out.println("=====success====");
47 } else {
48 System.out.println("=====fail=======");
49 }
50 }
51
52 /**
53 * 生成随機的6位數,短信驗證碼
54 * @return
55 */
56 private static String getMsgCode() {
57 int n = 6;
58 StringBuilder code = new StringBuilder();
59 Random ran = new Random();
60 for (int i = 0; i < n; i++) {
61 code.append(Integer.valueOf(ran.nextInt(10)).toString());
62 }
63 return code.toString();
64 }
65 }
将代碼中的your accessKeyId和your accessKeySecret替換成你剛才申請或者已有的access_key和access_secret;your phoneNumber替換成你想要接收短信的那個手機号碼;your signName替換之前申請到的簽名名稱;your templateCode也替換成控制台上面顯示的那個code。代碼中,短信驗證碼code為變量,裡面的值可以自己定義規則生成并替換,可以是随機生成的的6位或者其他位的數字或者字母。
Gitee碼雲:https://gitee.com/lyc96/projects
原文位址:http://tencent.yundashi168.com/630.html (通路原文可以完整檢視失效的圖檔和内容)