1. 程式人生 > >阿裏雲短信接口開發實踐(Java

阿裏雲短信接口開發實踐(Java

支持 域名 maven工程 println 9.png .post cep per ets

隨著互聯網的興起,各行各業的需求都在不斷的增加。隨著業務的擴大,企業給用戶發送短信驗證碼的業務,也是如火如荼。在這裏,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/55359.htmlspm=a2c4g.11186623.2.8.YwsgNT
這裏建議使用在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位或者其他位的數字或者字母。

技術分享圖片

阿裏雲短信接口開發實踐(Java