阿里雲簡訊開發
阿新 • • 發佈:2018-11-05
使用阿里雲簡訊開發前提必須企業申請,並且實名認證,此文只講解簡訊開發程式碼結構。
/** * 阿里簡訊配置 */ public class StaticPeram { /** * 手機驗證部分配置 */ /** * 設定超時時間-可自行調整 */ public final static String defaultConnectTimeout = "sun.net.client.defaultConnectTimeout"; public final static String defaultReadTimeout = "sun.net.client.defaultReadTimeout"; public final static String Timeout = "10000"; /** * 初始化ascClient需要的幾個引數 * 簡訊API產品名稱(簡訊產品名固定,無需修改) */ public final static String product = "Dysmsapi"; /** * 簡訊API產品域名(介面地址固定,無需修改) */ public final static String domain = "dysmsapi.aliyuncs.com"; /** * 你的accessKeyId,填你自己的 上文配置所得 自行配置 */ public final static String accessKeyId = ""; /** * 你的accessKeySecret,填你自己的 上文配置所得 自行配置 */ public final static String accessKeySecret = ""; /** * 必填:簡訊簽名-可在簡訊控制檯中找到 */ public final static String SignName = ""; /** * 必填:簡訊模板-可在簡訊控制檯中找到 */ public final static String TemplateCode = ""; }
傳送簡訊業務:
/** * @Author: hezhiyu * @Date: 2018/9/18 14:29 * @Description: 簡訊驗證碼 */ @RestController public class AliyunSendSmsController extends BaseController{ private final Logger logger = LoggerFactory.getLogger(AliyunSendSmsController.class); private static String code ; /** * 傳送驗證碼 * @param mobile * @return */ @RequestMapping(value="/sendSms", method={RequestMethod.POST}) public String getPhonemsg(String mobile) { /** * 進行正則關係校驗 */ logger.info("手機號:{}",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; final String domain = StaticPeram.domain; // 替換成你的AK final String accessKeyId = StaticPeram.accessKeyId; final String accessKeySecret = StaticPeram.accessKeySecret; // 初始化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("{ \"name\":\""+code+"\"}"); // 可選-上行簡訊擴充套件碼(無特殊需求使用者請忽略此欄位) // request.setSmsUpExtendCode("90997"); // 可選:outId為提供給業務方擴充套件欄位,最終在簡訊回執訊息中將此值帶回給呼叫者 request.setOutId("yourOutId"); // 請求失敗這裡會拋ClientException異常 SendSmsResponse sendSmsResponse; try { sendSmsResponse = acsClient.getAcsResponse(request); if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) { // 請求成功 logger.info("獲取驗證碼成功!!!"); } else { //如果驗證碼出錯,會輸出錯誤碼告訴你具體原因 logger.info("獲取驗證碼失敗..."); logger.info(sendSmsResponse.getCode()); return "false"; } } catch (ServerException e) { e.printStackTrace(); return "由於系統維護,暫時無法註冊!!!"; } catch (ClientException e) { e.printStackTrace(); return "由於系統維護,暫時無法註冊!!!"; } // String sysnCode = code; return "true"; } /** * 生成6位隨機數驗證碼 * @return */ public static String vcode(){ String vcode = ""; for (int i = 0; i < 6; i++) { vcode = vcode + (int)(Math.random() * 9); } return vcode; } }
只要把accessKeyId、accessKeySecret、SignName、TemplateCode填寫完整就能順利傳送驗證碼到手機上
2018-09-18 15:50:17.658 INFO 23296 --- [nio-9090-exec-4] c.m.controller.AliyunSendSmsController : 手機號:17620352790
2018-09-18 15:50:17.953 INFO 23296 --- [nio-9090-exec-4] c.m.controller.AliyunSendSmsController : 獲取驗證碼成功!!!