300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 阿里云短信服务接入流程

阿里云短信服务接入流程

时间:2019-05-06 03:03:20

相关推荐

阿里云短信服务接入流程

背景

在最近的项目需求中, 需要将复用阿里短信能力, 实现用户手机号验证: 如果用户号码验证通过后, 可以让用户上传文件资料并进行打印.

故核心内容就是:阿里云短信服务接入, 下面我们主要来介绍下阿里云短信服务接入流程

一. 熟悉整个对接流程

进入阿里云短信服务新手指引页面

可以看到整个对接流程如下图所示:

每个过程如下图所示:

二. 具体搭建过程

准备工作

注册后登录云通信产品试用界面

进行实名认证,如下图所示

开通短信服务

购买免费的短信包, 然后零元购后就可以在短信控制台进行配置

点击进入 阿里云短信服务控制台. 这里可以修改每分钟, 每小时, 每天发送信息的频率

获取AccessKey

在阿里云短信服务控制台右上角点击AccessKey管理

创建用户组

配置用户组权限

在用户组-添加组成员页面新建用户

新建用户

新建用户配置(该用户属于子用户, 用于发送短信)

复制并保存 AccessKey ID和AccessKey Secret, 以便在后续SDK中使用

(这一步非常重要, 因为AccessKey ID 和 AccessKey Secret只显示一次, 无法找回, 只能重新生成)

添加签名

注意: 如果仅仅测试的话, 可以跳过添加签名添加模板步骤. 直接调用sdk, 并使用无限制的测试签名和模板进行测试

添加签名设置

根据用途选择适用场景和签名用途, 然后进行审核

添加模板

创建模板

模板就是指短信模板, 具体就是在发送验证短信时, 短信发送内容的模板

配置短信模板内容后进行审核, 审核通过即可使用

发送短信(SDK)

注意: 这里因为使用sdk进行测试调用, 因此无需等待签名和模板审核成功. 使用下面短信测试专用的签名和模板编码即可

SignName: 阿里云短信测试,

TemplateCode: SMS_154950909

整体流程

进入OpenApi页面 -> 添加参数 -> 发起调用 -> 复制生成的sdk代码 -> 下载jar包->封装并复用代码

配置测试手机号

因为使用的是测试模板和签名, 因此需要我们配置用于测试的手机号

否则则会提示:只能向已回复授权信息的手机号发送

在线调用sdk

这里调用成功后, 就会发送短信.

查看是否调用成功(成功后复制sdk代码)

发起调用成功并收到短信后(如下图), 复制上图右侧生成的sdk示例代码到项目中

添加依赖( 获取sdk的jar包 )

如果是maven项目. 直接复制下图展示的Maven坐标

注意:如果是SSM/JavaEE项目(需要手动放入jar), 配置过程如下

直接将下图包放到指定目录下(博客底部会将jar分享)

Project Structure->Libraries中, 将lib下面的jar添加到项目中

选择jar所在目录, 添加后如下图所示

添加成功后, 对应的sdk代码则不会报红, 项目也可以正常运行

三. 封装sdk方法

将上一步的sdk方法进行封装

这里主要有三个方法: 第一个用于使用AK&SK初始化账号Client, 第二个用于生成6位验证码. 第三个用于获取发送短信结果

import com.aliyun.dysmsapi0525.Client;import com.aliyun.dysmsapi0525.models.SendSmsResponse;import com.aliyun.tea.TeaException;import com.aliyun.teaopenapi.models.Config;import org.ponent;/*** info:** @Author caoHaiYang* @Date /8/29 11:47*/@Componentpublic class SendSms {public static final String accessKeyId = "你的accessKeyId ";public static final String accessKeySecret = "你的accessKeySecret ";public static final String templateCode = "SMS_154950909";public static final String signName = "阿里云短信测试";/*** 使用AK&SK初始化账号Client* @param accessKeyId* @param accessKeySecret* @return Client* @throws Exception*/public static com.aliyun.dysmsapi0525.Client createClient(String accessKeyId, String accessKeySecret) throws Exception {Config config = new com.aliyun.teaopenapi.models.Config()// 您的 AccessKey ID.setAccessKeyId(accessKeyId)// 您的 AccessKey Secret.setAccessKeySecret(accessKeySecret);// 访问的域名config.endpoint = "";return new com.aliyun.dysmsapi0525.Client(config);}/*** 获取6位验证码* @return*/public String getVerifyCode() {Long codeL = System.nanoTime();String codeStr = Long.toString(codeL);String verifyCode = codeStr.substring(codeStr.length() - 6);System.out.println("生成的6位验证码为:" + verifyCode);return verifyCode;}/*** 发送短信* @param phoneNumber 手机号* @throws Exception* @return 短信验证码(如果为null说明出现错误)*/public String sendMessage(String phoneNumber) throws Exception {//随机生成6位验证码String verifyCode = this.getVerifyCode();Client client = SendSms.createClient(accessKeyId, accessKeySecret);com.aliyun.dysmsapi0525.models.SendSmsRequest sendSmsRequest = new com.aliyun.dysmsapi0525.models.SendSmsRequest().setPhoneNumbers(phoneNumber).setSignName(signName).setTemplateCode(templateCode).setTemplateParam("{\"code\":\""+verifyCode+"\"}");com.aliyun.teautil.models.RuntimeOptions runtime = new com.aliyun.teautil.models.RuntimeOptions();try {// 复制代码运行请自行打印 API 的返回值SendSmsResponse sendSmsResponse = client.sendSmsWithOptions(sendSmsRequest, runtime);System.out.println(sendSmsResponse.getBody().getMessage());return verifyCode;} catch (TeaException error) {// 如有需要,请打印 errorcom.mon.assertAsString(error.message);} catch (Exception _error) {TeaException error = new TeaException(_error.getMessage(), _error);// 如有需要,请打印 errorcom.mon.assertAsString(error.message);}return null;}}

新建短信发送业务

/*** 发送短信业务* @Author caoHaiYang* @Date /8/29 13:47*/public interface SendMessageService {/*** 短信发送接口* @param phoneNumber* @return*/int sendMessage(String phoneNumber) throws Exception;/*** 验证短信码* @param phoneNumber* @param verifyCode* @return*/int verifyMessageCode(String phoneNumber, String verifyCode);}

创建业务实现类

这里的逻辑就是:

发送短信接口传入手机号之后, 调用sendSms.sendMessage返回验证码, 然后将手机号作为key验证码作为value放入redis中并设置过期时间. 而在验证短信码接口调用时: 根据传入的手机号去redis中查验证码, 将查询到的验证码和接口传入的验证码进行比对. 成功返回1, 不成功返回0

import com.ring.config.Constants;import com.ring.config.JedisPoolUtil;import com.ring.model.BannerBean;import com.ring.service.SendMessageService;import com.ring.sms.SendSms;import mons.lang3.StringUtils;import org.springframework.stereotype.Service;import redis.clients.jedis.Jedis;import javax.annotation.Resource;/*** info:** @Author caoHaiYang* @Date /8/29 16:07*/@Servicepublic class SendMessageServiceImpl implements SendMessageService {@Resourceprivate SendSms sendSms;@Overridepublic int sendMessage(String phoneNumber) throws Exception {//通过阿里sms发送短信String verifyCode = sendSms.sendMessage(phoneNumber);if (StringUtils.isEmpty(verifyCode)) {return 0;}//将短信保存到redis中Jedis jedis = null;try {jedis = JedisPoolUtil.getJedis();jedis.auth(Constants.REDIS_PASSWORD);jedis.select(Constants.REDIS_DB);jedis.setex(phoneNumber, 600, verifyCode);return 1;} catch (Exception e) {e.printStackTrace();}return -1;}@Overridepublic int verifyMessageCode(String phoneNumber, String verifyCode) {Jedis jedis = null;try {jedis = JedisPoolUtil.getJedis();jedis.auth(Constants.REDIS_PASSWORD);jedis.select(Constants.REDIS_DB);String currentVerifyCode = jedis.get(phoneNumber);if (verifyCode.equals(currentVerifyCode)) {return 1;}} catch (Exception e) {e.printStackTrace();}return 0;}}

生成代码操作

在测试完短信验证码后, 我们可以根据以下流程流程编写其他接口代码

进入OpenApi页面 -> 添加参数 -> 发起调用 -> 复制生成的sdk代码 -> 封装并复用代码

当前阿里云短信服务可以提供的接口如下图所示

查询发送详情

发送成功后, 可以在短信服务控制台查看发送详情

查看指定时段短信发送量

查看短信具体发送内容

/s/1a3FeYANNIEo8ZvO5tIPeJg?pwd=pces

链接:/s/1a3FeYANNIEo8ZvO5tIPeJg

关注后进入私聊, 回复括号内关键字[短信服务] 获取阿里云短信服务jar包提取码

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。