package com.jjc.jjcv9smsservice.service;
import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
import com.jjc.api.sms.ISMS;
import com.aliyuncs.dysmsapi.model.v20170525.*;
import com.jjc.api.sms.pojo.ResultBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
/**
-
@jjc
-
@2019/3/21
*/
@Component
public class SMSService implements ISMS {@Value(" s m s . a c c e s s I d " ) p r i v a t e S t r i n g a c c e s s I d ; @ V a l u e ( " {sms.accessId}") private String accessId; @Value(" sms.accessId")privateStringaccessId;@Value("{sms.accessKey}")
private String accessKey;
@Value(" s m s . s i g n N a m e " ) p r i v a t e S t r i n g s i g n N a m e ; @ V a l u e ( " {sms.signName}") private String signName; @Value(" sms.signName")privateStringsignName;@Value("{sms.codeTemplate}")
private String codeTemplate;
@Value(" s m s . m y p r o d u c t " ) p r i v a t e S t r i n g m y p r o d u c t ; / / 短 信 A P I 产 品 名 称 ( 短 信 产 品 名 固 定 , 无 需 修 改 ) @ V a l u e ( " {sms.myproduct}") private String myproduct; //短信API产品名称(短信产品名固定,无需修改) @Value(" sms.myproduct")privateStringmyproduct;//短信API产品名称(短信产品名固定,无需修改)@Value("{sms.mydomain}")
private String mydomain;@Override
public String sendCode(String mobile, String code) {
if (mobile.isEmpty() || code.isEmpty()) {
//System.out.println(“手机号或验证码为空”);
return ResultBean.error;
}
//设置超时时间-可自行调整
System.setProperty(“sun.net.client.defaultConnectTimeout”, “10000”);
System.setProperty(“sun.net.client.defaultReadTimeout”, “10000”);
//初始化ascClient需要的几个参数
final String product =myproduct;//短信API产品名称(短信产品名固定,无需修改)
final String domain = mydomain ; //短信API产品域名(接口地址固定,无需修改)
//替换成你的AK
final String accessKeyId = accessId;//你的accessKeyId,参考本文档步骤2
final String accessKeySecret = accessKey;//你的accessKeySecret,参考本文档步骤2
//初始化ascClient,暂时不支持多region(请勿修改)
IClientProfile profile = DefaultProfile.getProfile(“cn-hangzhou”, accessKeyId,
accessKeySecret);
try {
DefaultProfile.addEndpoint(“cn-hangzhou”, “cn-hangzhou”, product, domain);
} catch (ClientException e) {
e.printStackTrace();
}
IAcsClient acsClient = new DefaultAcsClient(profile);
//组装请求对象
SendSmsRequest request = new SendSmsRequest();
//使用post提交
request.setMethod(MethodType.POST);
//必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式;发送国际/港澳台消息时,接收号码格式为国际区号+号码,如“85200000000”
request.setPhoneNumbers(mobile);
//必填:短信签名-可在短信控制台中找到
request.setSignName(signName);
//必填:短信模板-可在短信控制台中找到,发送国际/港澳台消息时,请使用国际/港澳台短信模版
request.setTemplateCode(codeTemplate);
//可选:模板中的变量替换JSON串,如模板内容为"亲爱的
n
a
m
e
,
您
的
验
证
码
为
{name},您的验证码为
name,您的验证码为{code}“时,此处的值为
//友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\r\n,否则会导致JSON在服务端解析失败
request.setTemplateParam(”{ “code”:"" + code + “”}");
//可选-上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)
//request.setSmsUpExtendCode(“90997”);
//可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
request.setOutId(“yourOutId”);
//请求失败这里会抛ClientException异常
SendSmsResponse sendSmsResponse = null;
try {
sendSmsResponse = acsClient.getAcsResponse(request);
} catch (ClientException e) {
e.printStackTrace();
}
if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals(“OK”)) {
//请求成功
}
return ResultBean.success;
}
}
测试类