阿里雲簡訊驗證碼、簡訊服務SDK、Java使用方法
阿新 • • 發佈:2019-02-15
阿里雲Java簡訊服務SDK
在這裡小小推薦下我的個人部落格
簡書:雷園的簡書
1. 首先在maven中新增依賴
<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>
2. 在阿里雲控制檯申請簽名
開啟阿里雲控制檯--》簡訊服務--》簽名管理--》添加簽名
需要在這裡申請一個簽名效果如下圖!
沒有這個是不行的,所以必須先申請簽名。如果是個人賬戶的話只能申請一個簽名,如果想要更換籤名的話必須把之前
的刪除掉才可以。而且申請時間比較久,需要慎重。
3. 申請模板 模板可以擁有多個,所以可以儘量根據簡訊的內容去編寫,模板例項如下 親愛的讀者${name},您借閱的${bookName}已經逾期${data}天,請及時歸還! 其中${name},${bookName},${data}為自定義變數,需要在java程式碼中進行填寫! 此為簡訊提醒服務,如果你是要做驗證碼 可以使用如下模板:您的校驗碼:${code},您正在註冊成為會員,感謝您的支援! 其中${code}為驗證碼。六位驗證碼生成方式如下
// 如果驗證碼為四位將1000000換成10000即可,驗證碼也可以是String型別,完全可以自由決定
int code = (int) (Math.random() * 1000000);
4.編寫Java程式碼
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.profile.DefaultProfile; import com.aliyuncs.profile.IClientProfile; public class Send { //產品名稱:雲通訊簡訊API產品,開發者無需替換 static final String product = "Dysmsapi"; //產品域名,開發者無需替換 static final String domain = "dysmsapi.aliyuncs.com"; // TODO 此處需要替換成開發者自己的AK(在阿里雲訪問控制檯尋找) // accessKeyId,accessKeySecret尋找步驟參考官方文件 //https://help.aliyun.com/document_detail/55284.html?spm=5176.10629532.106.1.24981cbeej0YCz static final String accessKeyId = "填寫你自己的accessKeyId"; static final String accessKeySecret = "填寫你自己的accessKeySecret"; // 方法名可以自行定義 // 引數可以自己定義隨意更改,更改為你自己需要的引數即可 // 返回值型別可以自行定義 public static String sendSms(String phone, String bookName, String userName) throws ClientException { //可自助調整超時時間 System.setProperty("sun.net.client.defaultConnectTimeout", "10000"); System.setProperty("sun.net.client.defaultReadTimeout", "10000"); //初始化acsClient,暫不支援region化 IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret); DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); IAcsClient acsClient = new DefaultAcsClient(profile); //組裝請求物件-具體描述見控制檯-文件部分內容 SendSmsRequest request = new SendSmsRequest(); //必填:待發送手機號 request.setPhoneNumbers(phone); //必填:簡訊簽名-可在簡訊控制檯中找到 request.setSignName("你自己的簽名名稱"); //必填:簡訊模板-可在簡訊控制檯中找到 request.setTemplateCode("你自己簡訊模板的模版CODE"); //可選:模板中的變數替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為 request.setTemplateParam("{\"name\":\":" + userName + "\"," + "\"bookName\":\"《" + bookName + "》\"}"); //選填-上行簡訊擴充套件碼(無特殊需求使用者請忽略此欄位) //request.setSmsUpExtendCode("90997"); //可選:outId為提供給業務方擴充套件欄位,最終在簡訊回執訊息中將此值帶回給呼叫者 request.setOutId("yourOutId"); //hint 此處可能會丟擲異常,注意catch SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request); return "success"; }