近期項目需要使用短信接口,對比下選擇了阿里的短信接口
以下為開發筆記:
maven pom.xml中引入:
<dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-sdk-core</artifactId> <version>4.1.0</version> </dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
<version>1.1.0</version>
</dependency>
在接口對接類中:
/** * 常量類 */ private static Constant constant; //產品名稱:雲通信短信API產品,開發者無需替換 static final String product = "Dysmsapi"; //產品域名,開發者無需替換 static final String domain = "dysmsapi.aliyuncs.com"; //此處需要替換成開發者自己的AK(在阿里雲訪問控制台尋找) static final String accessKeyId = constant.accessKeyId; static final String accessKeySecret = constant.accessKeySecret;
此處相關AK需要自己去阿里控制台查詢
方法調用:
/** * 短信接口 * @author zk *@date: 2019年5月30日 下午3:59:15 * @param phone * @param status 1:注冊 * @return */ @RequestMapping("/getSms") @ResponseBody public String getSms(String phone,String status) { //可自助調整超時時間 System.setProperty("sun.net.client.defaultConnectTimeout", "10000"); System.setProperty("sun.net.client.defaultReadTimeout", "10000"); //初始化acsClient,暫不支持region化 IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret); try { DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); } catch (ClientException e1) { e1.printStackTrace(); } IAcsClient acsClient = new DefaultAcsClient(profile); //隨機生成六位驗證碼 int code = (int)((Math.random()*9+1)*100000); Sendsms sendsmsselect = new Sendsms(); sendsmsselect.setIsdel("0"); sendsmsselect.setStatus(status); sendsmsselect.setPhone(phone); List<Sendsms> list = sendsmsService.selectAll(sendsmsselect); if(list!=null){ if(list.size()>0){ Sendsms sendsms1 = list.get(0); sendsms1.setIsdel("1");//刪除前一次該號碼記錄 sendsmsService.updateByPrimaryKey(sendsms1); } } /** * 驗證碼與號碼存入數據庫 */ sendsmsselect.setCode(code+""); sendsmsselect.setCreatetime(new Date()); sendsmsService.insert(sendsmsselect); //組裝請求對象-具體描述見控制台-文檔部分內容 SendSmsRequest request = new SendSmsRequest(); //必填:待發送手機號 request.setPhoneNumbers(phone); //必填:短信簽名-可在短信控制台中找到,你在簽名管理里的內容 request.setSignName(constant.SignName); //必填:短信模板-可在短信控制台中找到,你模板管理里的模板編號 request.setTemplateCode(constant.TemplateCode); //可選:模板中的變量替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為 request.setTemplateParam("{\"code\":\""+code+"\"}"); //選填-上行短信擴展碼(無特殊需求用戶請忽略此字段) //request.setSmsUpExtendCode("90997"); //可選:outId為提供給業務方擴展字段,最終在短信回執消息中將此值帶回給調用者 request.setOutId("yourOutId"); //hint 此處可能會拋出異常,注意catch SendSmsResponse sendSmsResponse = null; try { sendSmsResponse = acsClient.getAcsResponse(request); } catch (ServerException e) { e.printStackTrace(); } catch (ClientException e) { e.printStackTrace(); } //獲取發送狀態 String cod = sendSmsResponse.getCode(); // System.out.println(cod); return cod; }
這里是做驗證使用的,所有有相關驗證碼生成和存儲數據庫操作,可替換為自己需要的部分