给客户开发信息发送功能的时候,需要涉及到短信发送。比如我们日常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+""; } }