小言_互联网的博客

手把手教你写一个获取短信验证码业务(基于Spring Boot+Redis+阿里云短信服务)

371人阅读  评论(0)

一、阿里云短信环境搭建

1、开启使用子用户,创建用户组和用户

点击进入阿里云控制台
登录成功后,点击AccessKey管理,在弹窗中选择开始使用子用户AccessKey


创建用户组之后,点击进入权限管理,添加短信管理权限


注意:用户创建成功后,我们需要立刻复制AccessKey ID和AccessKey Secret的值,因为AccessKey Secre很快就会消失。
当我们点击进入用户时,我们可以看到AccessKey ID的值,但是AccessKey Secret已经看不到啦。

2、开通阿里云短信服务





这里的签名管理和模板管理都需要进行审核,在申请理由的那一栏中,填写的理由一定要正当,否则无法审核通过的哦!

上述工作完成之后,你还忘记一件事哦,既然开通短信服务,发送短信是要收费的,我们需要进行充值几块钱就可以的。

二、环境测试

1、新建Spring Boot(web)项目,导入依赖

<dependency>
    <groupId>com.aliyun</groupId>
    <artifactId>aliyun-java-sdk-core</artifactId>
    <version>4.5.0</version>
</dependency>

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.62</version>
</dependency>

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

2、在测试类中进行测试

	@Test
    void contextLoads() {
        // 连接阿里云
        DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "你的ID", "你的密码");
        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", "填写手机号码");
        request.putQueryParameter("SignName", "填写签名");
        request.putQueryParameter("TemplateCode", "填写模板");

        // 构建一个短信验证码
        HashMap<String, Object> map = new HashMap<>();
        map.put("code",6666);
        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();
        }
    }


运行程序,将会得到如下图所示的短信。

其中,【】里面的内容代表签名,数字6666代表验证码,除此之外的信息为模板。

三、真实业务场景实现

1、添加redis的相关配置

server.port=9090
# REDIS (RedisProperties)
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host=127.0.0.1
# Redis服务器连接端口
spring.redis.port=6379
# 连接池最大连接数(使用负值表示没有限制)
spring.redis.jedis.pool.max-active=8
# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.jedis.pool.max-wait=-1
# 连接池中的最大空闲连接
spring.redis.jedis.pool.max-idle=8
# 连接池中的最小空闲连接
spring.redis.jedis.pool.min-idle=0
# 连接超时时间(毫秒)
spring.redis.timeout=5000

2、在templates下面添加页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="app">
    <form action="#" method="post">
        请输入号码:<input type="text" v-model="phone"><br>
        <input type="text">
        <input type="button" value="获取验证码" @click="login">
    </form>
</div>


<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
    var app = new Vue({
        el:"#app",
        data:{
            phone:""
        },
        methods:{
            login(){
                axios.post("http://localhost:9090/send?phone="+this.phone).then((res)=>{
                    console.log(res.data);
                })
            }
        }

    })
    
</script>
</body>
</html>

这里使用Vue来实现前后端的分离。

3、新建SendSms接口并创建实现类SendSmsImpl

public interface SendSms {
    public boolean send(String phoneNumbers, String templateCode, Map<String,Object> code);
}
@Service
public class SendSmsImpl implements SendSms {
    @Override
    public boolean send(String phoneNumbers, String templateCode, Map<String, Object> code) {
        // 连接阿里云
        DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "你的ID", "你的密码");
        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", phoneNumbers);
        request.putQueryParameter("SignName", "你的签名");
        request.putQueryParameter("TemplateCode", templateCode);

        /*// 构建一个短信验证码
        HashMap<String, Object> map = new HashMap<>();
        map.put("code", 6666);*/
        request.putQueryParameter("TemplateParam", JSONObject.toJSONString(code));

        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、编写controller层

@RestController
@CrossOrigin    // 跨域
public class SmsApiController {

    @Autowired
    private SendSms sendSms;

    @Autowired
    private RedisTemplate<String,String> redisTemplate;

    @PostMapping("/send")
    public String code(String phone) {
        // 调用发送方法
        String code = redisTemplate.opsForValue().get(phone);
        if (!StringUtils.isEmpty(code)) {
            return phone + ":" + code + "已存在,还没有过期";
        }
        // 生成验证码并存储到redis中
        code = UUID.randomUUID().toString().substring(0, 4);
        HashMap<String, Object> param = new HashMap<>();
        param.put("code",code);

        boolean isSend = sendSms.send(phone, "SMS_192195645", param);
        if (isSend) {
            redisTemplate.opsForValue().set(phone,code,5, TimeUnit.SECONDS);
            return phone + ":" + code + "发送成功";
        }else {
            return "发送失败";
        }
    }
}

5、运行结果


先输入手机号码,然后点击获取验证码即可获取验证码。

这里的验证码是一个随机的四位数,不再是一个固定的值。


转载:https://blog.csdn.net/weixin_41842236/article/details/106558708
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场