给客户开发信息发送功能的时候,需要涉及到短信发送。比如我们日常app的登录功能,很多都使用到了手机验证码校验登录;比如修改密码,很多也用到了手机验证码验证进行修改密码。
阿里云短信服务(Short Message Service)是阿里云为用户提供的一种通信服务的能力。
实现步骤:
1.要实现阿里云短信接口,必须在阿里云平台上开通短信服务
1)登录阿里云服务平台,进入主页面
2)看到右上角有个控制台,点进去,然后选择产品与服务,找到云通信-短信服务
3)开通短信服务
点击服务短信之后,会进入短信服务页面,如果你是第一次使用,点击同意立即开通
2.进行实名认证
如果你没有进行过实名认证,系统会提示你进入实名认证界面进行实名认证,步骤如下:
弹出提示框的时候,点击“去实名认证”--->个人实名认证--->个人支付宝授权认证
3.创建签名和模板
1)点击右边,添加签名
2)选择签名使用场景
在这里提示下,验证码适用场景只能适用于验证码业务,审批容易通过;通用场景审核严格,但是都可以使用
3)创建短信模板
4)申请短信模板,可以使用常用模板申请,方便快捷
4.获取签名和短信模板
1)获取申请成功的签名
2)获取申请成功的短信模板
3)获取AccessKey ID和AccessKey Secret
5.写代码(IDEA)
1)在pom.xml里导入依赖(注意,有可能会有包版本问题,具体按照自己JDK版本选择依赖包版本)
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>4.0.6</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
<version>1.1.0</version>
</dependency>
2)创建短信发送工具类,具体的AK由刚刚获取的填入
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.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
/**
* @author 拾万个为什么
* @since JDK1.8
*/
public class SendSMSUti {
// 自己的AK
private static final String accessKeyId = ";// 你的accessKeyId
private static final String accessKeySecret = "7";// 你的accessKeySecret
private static final String signName = "";// 签名
private static final String templateCode = "";// 短信模板
private static int code;
/**
* @Description:发送手机验证码
* @Param:需要发送的手机号码
* @return:OK表示成功,失败则返回失败信息
*/
public String senSMSUtil(String phoneNumber) {
// 设置超时时间-可自行调整
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产品域名(接口地址固定,无需修改)
// 初始化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(phoneNumber);
request.setSignName(signName);
// 必填:短信模板-可在短信控制台中找到,发送国际/港澳台消息时,请使用国际/港澳台短信模版
request.setTemplateCode(templateCode);
//随机生成六位验证码
code = (int) ((Math.random() * 9 + 1) * 100000);
// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
// 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
request.setTemplateParam("{code:" + code + "}");
// 请求失败这里会抛ClientException异常
SendSmsResponse sendSmsResponse = null;
try {
sendSmsResponse = acsClient.getAcsResponse(request);
} catch (ClientException e) {
e.printStackTrace();
return "请求失败";
}
assert sendSmsResponse.getCode() != null;
if (sendSmsResponse.getCode() == null || !sendSmsResponse.getCode().equals("OK")) {// 发送不成功
return sendSmsResponse.getMessage();
}
// 请求成功
return "OK";
}
public int getCode() {
return code;
}
}
3)使用工具类
/**
* @author 拾万个为什么
* @since JDK1.8
*/
public class UseMyUtils{
public String sendSMS(String phoneNumber) {
//传入需要接收短信的手机号码
//创建短信工具类对象用来发送短信
SendSMSUtil sendSMS = new SendSMSUtil();
//发送短信并获取短信内容
String result = sendSMS.senSMSUtil(phoneNumber);
// 发送不成功
if (result == null || !OK.equals(result)) {
return "验证码发送失败";
}
//获取验证码
int code = sendSMS.getCode();
return code+"";
}
}