Spring boot 项目(十一)——使用腾讯云集成短信验证

引言

使用腾讯云:与微信公众号进行对接,使短信的签名和模板审核能够通过
使用阿里云:需要有上线的网站或者app

前期准备

01、需要有一个个人公众号。如果没有,请去微信公众平台创建一个订阅号(个人只能创建订阅号)

02、打开腾讯云,搜索短信,找到应用管理下的应用列表,创建应用
在这里插入图片描述
03、备份创建完成的AppID和App Key(编写代码需要用)
在这里插入图片描述
04、打开国内短信,创建签名模板和短信模板
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
05、等待审核通过
06、集成好Redis,用作存储短信验证码。如果你还没有集成好Redis,请参考此篇文章:
Spring boot 项目(十)——集成 Redis

代码部分

01、导入maven依赖

<!--腾讯云短信服务SDK-->
        <dependency>
            <groupId>com.github.qcloudsms</groupId>
            <artifactId>qcloudsms</artifactId>
            <version>1.0.2</version>
        </dependency>

02、创建用于储存信息的实体类

import lombok.Data;
@Data
public class SMSParameter {
	// 应用里的 AppId
    private int appId = xxxxx;
	// 应用里的 App Key
    private String appKey = "xxxxx";
	// 可有可无
    private String[] phoneNumbers;
	// 正文模板里的 id
    private int templateId = xxxx;
	// 签名里的内容
    private String smsSign = "xxxxx";
}

03、编写生成随机验证码的工具类

package com.demo.qcby.util;

import java.security.SecureRandom;
import java.util.Random;

public class VerCodeGenerateUtil {
    private static final String SYMBOLS = "0123456789";//ABCDEFGHIGKLMNOPQRSTUVWXYZ
    private static final Random RANDOM = new SecureRandom();
    //生成 6 位数的随机数字
    public static String generateVerCode() {
        char[] numbers = new char[6];
        for (int i = 0; i < numbers.length; i++) {
            numbers[i] = SYMBOLS.charAt(RANDOM.nextInt(SYMBOLS.length()));
        }
        return new String(numbers);
    }
}

04、编写发送信息的实现层代码

package com.information.controller;

import com.github.qcloudsms.SmsSingleSender;
import com.github.qcloudsms.SmsSingleSenderResult;
import com.github.qcloudsms.httpclient.HTTPException;
import com.information.common.web.ResultJson;
import com.information.entity.SMSParameter;
import com.information.util.RedisUtil;
import com.information.util.VerCodeGenerateUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.io.IOException;

/**
 * 短信验证的控制层
 *
 * @author lx
 * @since 2021-12-02 13:18:15
 */
@RestController
@RequestMapping
@Slf4j
public class TestController {
    @Resource
    private RedisUtil redisUtil;

    /*
    * @Description:发送短信验证码
    * @param phone
    */
    @RequestMapping("sendText")
    public ResultJson sendText(String phone) throws HTTPException, IOException {
        SMSParameter smsParameter=new SMSParameter();
        // 生成 随机验证码
        String ver = VerCodeGenerateUtil.generateVerCode();
        // 这里对应你的短信模板,如果需要传递两个参数,那么字符串数组应该有两个值
        String[] code = new String[]{ver,""+10};

        //写入redis中缓存
        redisUtil.setCacheObject(phone,ver);
        redisUtil.expire(phone,10*60);

        //获得 id 和 key
        SmsSingleSender sender = new SmsSingleSender(smsParameter.getAppId(), smsParameter.getAppKey());
//        SmsSingleSenderResult result = sender.sendWithParam("86", phone, smsParameter.getTemplateId(),
//               code, smsParameter.getSmsSign(), "", "" );
        //发送短信,86 指的是国内短信,第二个是模板的 id,第三个是传递的参数,第四个是签名内容,后面两个可以传递空
        SmsSingleSenderResult result = sender.sendWithParam("86", phone, smsParameter.getTemplateId(),
                code, smsParameter.getSmsSign(), "", "");
        // 如果 result 的结果是 0,说明发送成功
        if (result.result == 0) {
            return ResultJson.success(code[0]);
        } else {// 如果结果不是 0,说明出错了,打印错误信息以帮助修改
            return ResultJson.failure(result.errMsg, result.sid);
        }
    }
    
    /*
    * @Description: 判断验证码是否一致
    * @param phone
     * @param code
    */
    @RequestMapping("judge")
    public String judge(String phone,String code){
        Object var=redisUtil.getCacheObject(phone);
        if (code.equals(var)){
            /*用户登录*/
            return "验证成功";
        }else{
            return "验证失败";
        }
    }
}

测试结果

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

--流星。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值