版权声明:本文为博主原创烂文章,你爱转载就转载 https://blog.csdn.net/qq_38623459/article/details/87346717
设置参数,根据阿里云指导文档一步一步很简单
申请签名与模板
短信参数不超过20,不然无法发送,逗号与数字都算一个
下面代码是根据号码数量自动选择发送方式(单发与群发)
单发与群发的参数设置等不一样,注意比对
package org.csm.bmxt.thread;
import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.dysmsapi.model.v20170525.SendBatchSmsRequest;
import com.aliyuncs.dysmsapi.model.v20170525.SendBatchSmsResponse;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
public class AliyunSmsUtils implements Runnable {
private String phoneNumarr;
private String templateParam;//模板替换内容
private String templateCode;//模板
private String signnamejson;//签名
//phoneNumarr可能是个字符串可能是个json对象数组(此情况应当其他参数也传正确)
public AliyunSmsUtils(String phoneNumarr,String signnamejson,String templateCode, String templateParam) {
super();
this.phoneNumarr = phoneNumarr;
this.templateParam = templateParam;
this.templateCode = templateCode;
this.signnamejson = signnamejson;
}
@Override
public void run() {
if(phoneNumarr.split(",").length==1){
try {
sendSms(phoneNumarr,templateCode,templateParam);
} catch (ClientException e) {
e.printStackTrace();
}
}else{//群发
try {
SendBatchSms(phoneNumarr,signnamejson,templateCode,templateParam);
} catch (ClientException e) {
e.printStackTrace();
}
}
}
//单发短信其实主要的内容就是手机号和内容,阿里云短信内容的模板需要在平台“备案”,此处内容固定,直接调用,有包括注册码请求、验证码请求、报名成功通知、临时通知群发与单发
public static SendSmsResponse sendSms(String mobile, String templateCode ,String templateParam)
throws ClientException {
// 可自助调整超时时间
System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("sun.net.client.defaultReadTimeout", "10000");
// 初始化acsClient,暂不支持region化
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou","XX","XXX");
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", "Dysmsapi", "dysmsapi.aliyuncs.com");
IAcsClient acsClient = new DefaultAcsClient(profile);
// 组装请求对象-具体描述见控制台-文档部分内容
SendSmsRequest request = new SendSmsRequest();
request.setMethod(MethodType.POST);
// 必填:待发送手机号(单发一个手机号)
request.setPhoneNumbers(mobile);
// 必填:短信签名-可在短信控制台中找到
request.setSignName("XX");
// 必填:短信模板-可在短信控制台中找到
request.setTemplateCode(templateCode);
// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
request.setTemplateParam(templateParam);
// 选填-上行短信扩展码(无特殊需求用户请忽略此字段)
// request.setSmsUpExtendCode("90997");
// 可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
//request.setOutId("yourOutId");
// hint 此处可能会抛出异常,注意catch
SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
//请求成功
System.out.println("=====success====");
} else {
System.out.println("=====fail======="+sendSmsResponse.getMessage());
System.out.println("=====fail======="+sendSmsResponse.getCode());
}
return sendSmsResponse;
}
//群发短信其实主要的内容就是手机号和内容,阿里云短信内容的模板需要在平台“备案”,此处内容固定,直接调用,有包括注册码请求、验证码请求、报名成功通知、临时通知群发与单发
public static SendBatchSmsResponse SendBatchSms(String phonenumberjson,String signnamejson, String templateCode ,String templateParam)
throws ClientException {
// 可自助调整超时时间
System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("sun.net.client.defaultReadTimeout", "10000");
// 初始化acsClient,暂不支持region化
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou","XX","XXX");
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", "Dysmsapi", "dysmsapi.aliyuncs.com");
IAcsClient acsClient = new DefaultAcsClient(profile);
// 组装请求对象-具体描述见控制台-文档部分内容
SendBatchSmsRequest request = new SendBatchSmsRequest();
request.setMethod(MethodType.POST);
// 必填:待发送手机号(手机号)
request.setPhoneNumberJson(phonenumberjson);
// 必填:短信签名-可在短信控制台中找到
request.setSignNameJson(signnamejson);
// 必填:短信模板-可在短信控制台中找到
request.setTemplateCode(templateCode);
// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
request.setTemplateParamJson(templateParam);
// 选填-上行短信扩展码(无特殊需求用户请忽略此字段)
// request.setSmsUpExtendCode("90997");
// 可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
//request.setOutId("yourOutId");
// hint 此处可能会抛出异常,注意catch
SendBatchSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
//请求成功
System.out.println("=====success====");
} else {
System.out.println("=====fail======="+sendSmsResponse.getMessage()+sendSmsResponse.getCode());
}
return sendSmsResponse;
}
}