阿里雲短信服務的申請,請直接參考官方文檔:短信發送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