隨着互聯網的興起,各行各業的需求都在不斷的增長。隨着業務的擴大,企業給用戶發送短信驗證碼的業務,也是如火如荼。在這裏,calvin給各位開發者推薦阿里雲短信平臺。緣由有二:1.接入較簡單,開發成本低 2.很是穩定,短信可達率99%。
OK,那麼接下來咱們就能夠開發阿里短信接口吧。主要包括兩個步驟,第一個是前期準備,包括註冊阿里雲帳號,得到access_key和access_secret,而且申請短信簽名和短信模板。第二個步驟則是引入阿里短信服務的SDK,並正式開發。javascript
1.註冊阿里雲帳號
進入網址 https://www.aliyun.com/ 點擊免費註冊,輸入相關信息,則成爲阿里雲用戶。html
2.獲取Access_key和Access_secretjava
3.簽名管理與模板管理
首先點擊產品與服務,選擇短信服務。git
咱們須要關心的是應用開發這塊。api
分別申請簽名管理和模板管理。app
注意,若是是我的學習使用,儘可能dom
前面的準備工做都作完而且都申請經過後,咱們能夠正式進入咱們的開發工做。
能夠先在IDEA中新建一個Maven工程。經過依賴阿里短信服務的SDK或者在pom文件中添加相關依賴。
SDK及Demo下載地址爲:
https://help.aliyun.com/document_detail/101874.html?source=5176.11533457&type=copypost
這裏建議使用在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>
瞭解一下入參與出參ui
根據官方給出的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 (訪問原文能夠完整查看失效的圖片和內容)