一小时学会使用SpringBoot整合阿里云SMS短信服务
发布日期:2021-06-29 18:10:35 浏览次数:2 分类:技术文章

本文共 6204 字,大约阅读时间需要 20 分钟。

在这里插入图片描述

1. 登录阿里云进入控制台

进入阿里云控制台,在个人头像位置点击进入AccessKey管理

在这里插入图片描述

在这里插入图片描述

2. 创建用户和用户组

创建用户组

在这里插入图片描述

添加完成后进入用户组,并为其添加权限:

在这里插入图片描述

创建用户

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

注意:用户创建完成后,将其添加到用户组中,点击进入该用户,在认证管理下方会有该用户对应的AccessKeyIdAccessKeySecret!要将其保存下来,不然忘记后,还得删除用户,重新创建,在之后使用代码整合短信业务时候需要用到!

3. 开通阿里云短信服务

阿里云短信服务地址:

在这里插入图片描述

在概览中直接点击立即开通短信服务!接下来点击快速学习:

在这里插入图片描述

点击添加签名,添加模板,去向阿里云申请自己定义的签名和短信模板!

在这里插入图片描述

在这里插入图片描述

模板和签名申请提交后等待申请结果通过即可!

注意:由于阿里云通信短信服务审核管理规则升级,12月17日以后,个人身份申请审核短信签名更加严格了

在这里插入图片描述

这里我审核用的是自己的公众号名称作为SMS短信签名,去申请的!

4. 代码整合阿里云SMS短信服务

官方SDK文档:

官方APIDemo:

4.1 pom.xml 中引入SDK依赖

Spring Boot版本我使用的是2.3.x:

com.aliyun
aliyun-java-sdk-core
4.5.3
com.alibaba
fastjson
1.2.68
org.springframework.boot
spring-boot-starter-data-redis

4.2 测试官方提供的实例Demo

@SpringBootTestclass AliyunSmsDemoApplicationTests {
@Test void contextLoads() {
/** * 连接阿里云: * * 三个参数: * regionId 不要动,默认使用官方的 * accessKeyId 自己的用户accessKeyId * accessSecret 自己的用户accessSecret */ DefaultProfile profile = DefaultProfile.getProfile( "cn-hangzhou", "LTAI4GKDZbrcaESV1fBV8V9B", "1bc8phOIbAbfvMXSWFt2AlLctBMMCI"); IAcsClient client = new DefaultAcsClient(profile); // 构建请求: CommonRequest request = new CommonRequest(); request.setSysMethod(MethodType.POST); request.setSysDomain("dysmsapi.aliyuncs.com"); request.setSysVersion("2017-05-25"); request.setSysAction("SendSms"); // 自定义参数: request.putQueryParameter("PhoneNumbers", "xxxxx0440");// 接收短信的手机号 request.putQueryParameter("SignName", "CSP网上商城");// 短信签名 request.putQueryParameter("TemplateCode", "SMS_20xxxxx74");// 短信模版CODE // 构建短信验证码 Map
map = new HashMap<>(); map.put("code",1234);// 这里仅用于测试,所以验证码写死 request.putQueryParameter("TemplateParam", JSONObject.toJSONString(map)); try {
CommonResponse response = client.getCommonResponse(request); System.out.println(response.getData()); } catch (ServerException e) {
e.printStackTrace(); } catch (ClientException e) {
e.printStackTrace(); } }}

执行发送测试,结果如下图:

4.3 构建短信发送微服务

4.3.1 service

/** * @Auther: csp1999 * @Date: 2020/12/18/12:08 * @Description: 阿里云SMS短信服务Service */@Servicepublic class AliyunSendSmsService {
@Value("${aliyun.sms.accessKeyId}") private String accessKeyId; @Value("${aliyun.sms.accessKeySecret}") private String accessKeySecret; /** * 发送短信验证码 * * @param phone 接收短信的手机号 * @param templateCode 短信模板CODE * @param codeMap 验证码map 集合 * @return */ public Boolean sendMessage(String phone, String templateCode, Map
codeMap) {
/** * 连接阿里云: * * 三个参数: * regionId 不要动,默认使用官方的 * accessKeyId 自己的用户accessKeyId * accessSecret 自己的用户accessSecret */ DefaultProfile profile = DefaultProfile.getProfile( "cn-hangzhou", accessKeyId, accessKeySecret); IAcsClient client = new DefaultAcsClient(profile); // 构建请求: CommonRequest request = new CommonRequest(); request.setSysMethod(MethodType.POST); request.setSysDomain("dysmsapi.aliyuncs.com"); request.setSysVersion("2017-05-25"); request.setSysAction("SendSms"); // 自定义参数: request.putQueryParameter("PhoneNumbers", phone);// 手机号 request.putQueryParameter("SignName", "CSP网上商城");// 短信签名 request.putQueryParameter("TemplateCode", templateCode);// 短信模版CODE // 构建短信验证码 request.putQueryParameter("TemplateParam", JSONObject.toJSONString(codeMap)); try {
CommonResponse response = client.getCommonResponse(request); System.out.println(response.getData()); return response.getHttpResponse().isSuccess(); } catch (ServerException e) {
e.printStackTrace(); } catch (ClientException e) {
e.printStackTrace(); } return false; }}

4.3.2 controller

/** * @Auther: csp1999 * @Date: 2020/12/18/12:21 * @Description: 阿里云SMS短信发送API */@RestControllerpublic class AliyunSmsApiController {
@Autowired private AliyunSendSmsService aliyunSendSmsService; @Autowired private RedisTemplate
redisTemplate; @Value("${aliyun.sms.templateCode}") private String templateCode; /** * 短信发送 * * @param phone * @return */ @GetMapping("/send/{phone}") public String sendCode(@PathVariable("phone") String phone) {
// 根据手机号从redis中拿验证码 String code = redisTemplate.opsForValue().get(phone); if (!StringUtils.isEmpty(code)) {
return phone + " : " + code + "已经存在,还没有过期!"; } // 如果redis 中根据手机号拿不到验证码,则生成4位随机验证码 code = UUID.randomUUID().toString().substring(0, 4); // 验证码存入codeMap Map
codeMap = new HashMap<>(); codeMap.put("code", code); // 调用aliyunSendSmsService发送短信 Boolean bool = aliyunSendSmsService.sendMessage(phone, templateCode, codeMap); if (bool) {
// 如果发送成功,则将生成的4位随机验证码存入redis缓存,5分钟后过期 redisTemplate.opsForValue().set(phone, code, 5, TimeUnit.MINUTES); return phone + " : " + code + "发送成功!"; } else {
return phone + " : " + code + "发送失败!"; } }}

4.3.3 application.yml

server:  port: 8080# spring相关配置spring:  redis:    # Redis数据库索引(默认为0)    database: 0    # Redis服务器地址    host: 8.xxx.xx.xx6    # Redis服务器连接端口    port: 6379    # Redis服务器连接密码(默认为空)    password: cspxxxxxxx    jedis:      pool:        # 连接池最大连接数(使用负值表示没有限制)        max-active: 8        # 连接池最大阻塞等待时间(使用负值表示没有限制)        max-wait: -1        # 连接池中的最大空闲连接        max-idle: 8        # 连接池中的最小空闲连接        min-idle: 0    # 连接超时时间(毫秒)    timeout: 8000

4.3.4 application.properties

# accessKeyIdaliyun.sms.accessKeyId=LTAI4xxxxxxxxxxV9B# accessKeySecretaliyun.sms.accessKeySecret=LTAI4xxxxxxxxxxV8V9B# 短信模板Codealiyun.sms.templateCode=SMS_xxxxx74

4.4 启动项目测试发送

在这里插入图片描述

手机收到短信验证码!

5. Demo地址

Demo案例源码参考:


  • 如果对大家有帮助,请三连支持一下!
  • 有问题欢迎评论区留言,及时帮大家解决!

在这里插入图片描述

转载地址:https://csp1999.blog.csdn.net/article/details/111398044 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:hibernate-validate的基本使用
下一篇:Linux下安装RabbitMQ并使用SpringBoot整合

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月25日 09时47分52秒