1. 程式人生 > >阿里雲簡訊驗證碼、簡訊服務SDK、Java使用方法

阿里雲簡訊驗證碼、簡訊服務SDK、Java使用方法

阿里雲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";
    }