簡訊服務API-簡訊驗證
阿新 • • 發佈:2020-07-14
需求
隨著網際網路的發展,資訊保安顯得尤為重要,在保證網際網路環境穩定執行的情況下,為了不讓一些人在網上搞破壞,採取實名認證的方式去約束其行為,不要覺得網路就是法外之地,簡訊驗證碼註冊的作用,一定程度上保證資訊真實性,也規範了使用者的使用行為。
阿里雲簡訊服務介面使用方式
這篇文件將用最快速的方式去讓讀者學會介面使用
1.註冊阿里雲賬號
2.實名認證
3.使用簡訊服務API介面,註冊簡訊模板,註冊簽名,註冊AccessKey,三者缺一不可。
官方文件
4.將下面給出程式碼中的模板,簽名,key值替換掉你的即可實現簡訊驗證碼接收(一條簡訊大概四分五)
maven包匯入
新增到pom.xml中
<dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-sdk-core</artifactId> <version>4.0.8</version> </dependency> <dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-sdk-dysmsapi</artifactId> <version>1.1.0</version> </dependency> <!-- https://mvnrepository.com/artifact/com.google.code.gson/gson --> <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.8.4</version> </dependency>
類1,介面配置資訊
package com.Message;//package com.Message; public class StaticPeram { final static String defaultConnectTimeout = "sun.net.client.defaultConnectTimeout"; final static String defaultReadTimeout = "sun.net.client.defaultReadTimeout"; final static String Timeout = "10000"; // 初始化ascClient需要的幾個引數 final static String product = "Dysmsapi";// 簡訊API產品名稱(簡訊產品名固定,無需修改) final static String domain = "dysmsapi.aliyuncs.com";// 簡訊API產品域名(介面地址固定,無需修改) // 替換成你的AK (產品密) final static String accessKeyId = "";// 你的accessKeyId,填你自己的 上文配置所得 自行配置 final static String accessKeySecret = "";// 你的accessKeySecret,填你自己的 上文配置所得 自行配置 // 必填:簡訊簽名-可在簡訊控制檯中找到 final static String SignName = "ahdy6"; // 阿里雲配置你自己的簡訊簽名填入 // 必填:簡訊模板-可在簡訊控制檯中找到 final static String TemplateCode = ""; // 阿里雲配置你自己的簡訊模板填入 }
類2,API,jar包方法執行
package com.Message;//package com.Message; 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.http.MethodType; import com.aliyuncs.profile.DefaultProfile; import com.aliyuncs.profile.IClientProfile; import com.google.gson.Gson; import org.springframework.expression.common.TemplateParserContext; public class PhoneCode { private static String code ; // public static void main(String[] args) { // String phone = "16655072520"; //此處可輸入你的手機號碼進行測試 // System.out.println(vcode()); // getPhonemsg(phone); // // // } /** * 阿里雲簡訊服務配置 * @param mobile * @return */ public static String getPhonemsg(String mobile) { /** * 進行正則關係校驗 */ System.out.println(mobile); if (mobile == null || mobile == "") { System.out.println("手機號為空"); return ""; } /** * 簡訊驗證---阿里大於工具 */ // 設定超時時間-可自行調整 System.setProperty(StaticPeram.defaultConnectTimeout, StaticPeram.Timeout); System.setProperty(StaticPeram.defaultReadTimeout, StaticPeram.Timeout); // 初始化ascClient需要的幾個引數 final String product = StaticPeram.product;// 簡訊API產品名稱(簡訊產品名固定,無需修改) final String domain = StaticPeram.domain;// 簡訊API產品域名(介面地址固定,無需修改) // 替換成你的AK final String accessKeyId = StaticPeram.accessKeyId;// 你的accessKeyId,參考本文件步驟2 final String accessKeySecret = StaticPeram.accessKeySecret;// 你的accessKeySecret,參考本文件步驟2 // 初始化ascClient,暫時不支援多region IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret); try { DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); } catch (ClientException e1) { e1.printStackTrace(); } //獲取驗證碼 code = vcode(); IAcsClient acsClient = new DefaultAcsClient(profile); // 組裝請求物件 SendSmsRequest request = new SendSmsRequest(); // 使用post提交 request.setMethod(MethodType.POST); // 必填:待發送手機號。支援以逗號分隔的形式進行批量呼叫,批量上限為1000個手機號碼,批量呼叫相對於單條呼叫及時性稍有延遲,驗證碼型別的簡訊推薦使用單條呼叫的方式 request.setPhoneNumbers(mobile); // 必填:簡訊簽名-可在簡訊控制檯中找到 request.setSignName(StaticPeram.SignName); // 必填:簡訊模板-可在簡訊控制檯中找到 request.setTemplateCode(StaticPeram.TemplateCode); // 可選:模板中的變數替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為 // 友情提示:如果JSON中需要帶換行符,請參照標準的JSON協議對換行符的要求,比如簡訊內容中包含\r\n的情況在JSON中需要表示成\\r\\n,否則會導致JSON在服務端解析失敗 request.setTemplateParam("{ \"code\":\""+code+"\"}"); // 可選-上行簡訊擴充套件碼(無特殊需求使用者請忽略此欄位) // request.setSmsUpExtendCode("90997"); // 可選:outId為提供給業務方擴充套件欄位,最終在簡訊回執訊息中將此值帶回給呼叫者 request.setOutId("yourOutId"); // 請求失敗這裡會拋ClientException異常 SendSmsResponse sendSmsResponse; try { sendSmsResponse = acsClient.getAcsResponse(request); if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) { // 請求成功 System.out.println("獲取驗證碼成功!!!"); } else { //如果驗證碼出錯,會輸出錯誤碼告訴你具體原因 System.out.println(sendSmsResponse.getCode()); System.out.println("獲取驗證碼失敗..."); } } catch (ServerException e) { e.printStackTrace(); return "由於系統維護,暫時無法註冊!!!"; } catch (ClientException e) { e.printStackTrace(); return "由於系統維護,暫時無法註冊!!!"; } return "true"; } /** * 生成6位隨機數驗證碼 * @return */ public static String vcode(){ String vcode = ""; for (int i = 0; i < 6; i++) { vcode = vcode + (int)(Math.random() * 9); } // Gson gson = new Gson(); // String code = gson.toJson(vcode); return vcode; } }
注意
${"此處值應與模板中一致,比如模板中為code,此處即為code",code};
遇到API錯誤碼可參考
官方文件解決方法