Java後端接入阿里雲短信API源碼分享

阿里雲短信服務的申請,請直接參考官方文檔:短信發送API(SendSms)---JAVA  ,本博客分享的是具體的後端代碼實現哦。

首先是要引入需要的jar包:

<!-- 阿里雲短信開始 -->
<!-- https://mvnrepository.com/artifact/com.github.suxingli/aliyuncs -->
<dependency>
    <groupId>com.github.suxingli</groupId>
    <artifactId>aliyuncs</artifactId>
    <version>1.0.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-dysmsapi -->
<dependency>
    <groupId>com.aliyun</groupId>
    <artifactId>aliyun-java-sdk-dysmsapi</artifactId>
    <version>1.1.0</version>
</dependency>
<!-- 阿里雲短信結束 -->

 

下面是實現代碼:

package util.mobile;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLEncoder;

import org.apache.log4j.Logger;

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.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;

public class SendSMS {
	
	private static final Logger logger = Logger.getLogger(SendSMS.class);
	
	public static void main(String[] args){
		String mobile="13888888888";//需要接受短信驗證碼的手機號
		String sendTemplate="SMS_134188888";//短信模板ID,需要去阿里雲平臺申請,審覈通過後方能使用,通常是以"SMS_"開頭字符串
		String code = (int)((Math.random() * 9 + 1) * 100000)+ "";//要發送給用戶的短信驗證碼,行業通常使用六位純數字

        String result= sendMsg(mobile,sendTemplate,code);
        if(result!=null&&"OK".equals(result.toUpperCase())){
            System.out.println("短信發送成功");
        }else{
            System.out.println("短信發送失敗");
        }
		
	}
	/**
	 * 通過阿里雲平臺發送短信,如果發送成功,返回"OK" ;否則返回的是錯誤信息
	 * @param mobile 要接收該短信的用戶手機號
	 * @param sendTemplate 短信模板id,此處將其封裝爲變量,是爲了由該方法的調用者決定自己來發送哪種類型的短信驗證碼,比如註冊,重置密碼類的
	 * @param code 您將發送到用戶手機的短信驗證碼
	 */
	public static String sendCode(String mobile,String sendTemplate,String code){
		//請求失敗這裏會拋ClientException異常
		String result="";
		try {
			//設置超時時間-可自行調整
			System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
			System.setProperty("sun.net.client.defaultReadTimeout", "10000");
			//初始化ascClient需要的幾個參數
			final String product = "Dysmsapi";//短信API產品名稱(短信產品名固定,無需修改)
			final String domain = "dysmsapi.aliyuncs.com";//短信API產品域名(接口地址固定,無需修改)
			//替換成你的AK
			final String accessKeyId = "LTAI3IJDEVkXgY0E";//你的accessKeyId,參考本文檔步驟2
			final String accessKeySecret = "kmnOeksdTEauInvea9Hf6dqssDdvho";//你的accessKeySecret,參考本文檔步驟2
			//初始化ascClient,暫時不支持多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();
			//使用post提交
			request.setMethod(MethodType.POST);
			//必填:待發送手機號。支持以逗號分隔的形式進行批量調用,批量上限爲1000個手機號碼,批量調用相對於單條調用及時性稍有延遲,驗證碼類型的短信推薦使用單條調用的方式;發送國際/港澳臺消息時,接收號碼格式爲00+國際區號+號碼,如“0085200000000”
			request.setPhoneNumbers(mobile);
			//必填:短信簽名-可在短信控制檯中找到
			request.setSignName("");//注意要與你在短信控制檯中的簽名一致
			//必填:短信模板-可在短信控制檯中找到
			request.setTemplateCode(sendTemplate);
			//可選:模板中的變量替換JSON串,如模板內容爲"親愛的${name},您的驗證碼爲${code}"時,此處的值爲
			//友情提示:如果JSON中需要帶換行符,請參照標準的JSON協議對換行符的要求,比如短信內容中包含\r\n的情況在JSON中需要表示成\\r\\n,否則會導致JSON在服務端解析失敗
//		request.setTemplateParam("{\"name\":\"Tom\", \"code\":\"123\"}");
			request.setTemplateParam("{\"code\":\""+code+"\"}");
			//可選-上行短信擴展碼(擴展碼字段控制在7位或以下,無特殊需求用戶請忽略此字段)
			//request.setSmsUpExtendCode("90997");
			//可選:outId爲提供給業務方擴展字段,最終在短信回執消息中將此值帶回給調用者
//		request.setOutId("yourOutId");
			 
			SendSmsResponse response = acsClient.getAcsResponse(request);
			result=response.getCode();
		} catch (Exception e) {
			result=e.getMessage();
		}
		return result;
	}
	
}

 

我通常會對每個用戶每天調用短信接口的次數做限制,同時後臺也會對短信驗證碼保存到redis數據庫中,具體的使用,請參考我的另一篇博客https://blog.csdn.net/weixin_42023666/article/details/89680342

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章