美文网首页SpringBoot
SpringBoot集成腾讯云短信服务发送短信

SpringBoot集成腾讯云短信服务发送短信

作者: JTravler | 来源:发表于2020-03-10 15:44 被阅读0次

    我们在使用APP、网站的过程中,都离不开短信的支持。比如:注册需要发送短信验证码,忘记密码需要发送验证码等等。所以接下来就把发送短信的具体实现过程记录下来,既是为了自己以后查阅方便,也是想分享给大家,如果有什么不足的地方欢迎大家不吝指出。

    我们只需要完成下面的几个步骤就可以发送短信了

    注册腾讯云以及完成认证

    1. 这里我使用的是腾讯云提供的短信服务,使用该服务之前我们需要完成认证,有个人认证和企业认证。这里我是个人认证,个人认证完成后提供100条免费短信发送,有效期是3个月,对于我们个人做测试是足够了。
    2. 注册并认证后,我们接下来就是在短信控制台中进行相关操作,下面网址就是直通到短信控制台页面。
      https://console.cloud.tencent.com/smsv2/manage-package 在这里插入图片描述
    3. 我们也可以查看官方文档教程,写的也比较详细,下面也给出网址。
      https://cloud.tencent.com/document/product/382/18071 在这里插入图片描述

    短信结构

    这里拿一张短信图片来说明,这是它官网教程的图片,短信主要由短信签名和短信模板组成。

    1. 短信签名就是下面红色框里面的内容:XXX
    2. 短信模板就是除了短信签名之外的所有内容


      在这里插入图片描述

      也就是我们我们接下来要创建属于自己的短信签名和短信模板,它们都需要经过审核通过后才能使用,要不然没法用...

    创建应用

    我们发送短信的时候,需要先创建应用。我们可以创建多个应用,每个应用都可以使用相同的短信签名和短信模板。创建应用不需要审核。

    1. 输入应用名称
    2. 输入应用简介


      在这里插入图片描述

      上面我创建了一个测试应用,我们直接点击应用名称,可以看到应用的详细内容,这里我们需要记住下图中两个红色框的内容。
      接下来我们使用短信API的时候要用到它们。


      在这里插入图片描述
      接下来我们就是要创建短信签名和短信模板了,如果它们都审核通过,我们就可以使用短信API发送短信了。

    创建短信签名

    1. 我们在1位置选择签名的类型,这里我使用的是网站,还有其他的选项...
    2. 如果选择的是网站,那么签名内容一定要是网站的名称,不是可能审核不通过...
    3. 证明上传可以查看3位置处的查看范例,它说明的比较详细...
    4. 申明说明要求被写网站域名,创建签名后就等待审核,一般半个钟之内就能知道结果


      在这里插入图片描述

    创建短信模板

    1. 输入模板名称,一般是以用途命名,比如:验证码...
    2. 我们可以在2位置选择标准模板,也可以跳过,直接在3位置处自定义我们的模板
    3. 模板中可能出现{1},{2},...这个表示的是变量,也就是我们可以在程序中动态指定它们,比如:验证码号码,有效时间...
    4. 创建模板后也需要审核,时间和签名差不多...


      在这里插入图片描述

      如果它们都审核通过,我们接下来就操作短信API来发送短信

    引入短信API

    我们需要使用腾讯云官方的API来发送短信,我们使用最常用的Maven依赖方式引入,主要下面一个依赖即可。

    <dependency>
        <groupId>com.github.qcloudsms</groupId>
        <artifactId>qcloudsms</artifactId>
        <version>1.0.6</version>
    </dependency>
    

    定义相关参数

    引入API后,我们需要定义发送短信需要的参数。下面的参数都是虚假的,大家在使用的时候对应写成自己的即可。
    因为是测试发送短信,所有参数都是固定写,没有动态指定。

    /**
     *  封装发送短信所需的参数
     */
    @Data
    public class SMSParameter {
        // 短信应用 SDK AppID,SDK AppID 以1400开头
        private int appId = XXX; 
        // 短信应用SDK AppKey
        private String appKey = "XXX";
        // 需要发送短信的手机号码,可以定义多个手机号码
        private String[] phoneNumbers = {"XXX","XXX"};
        // 短信模板ID,需要在短信控制台中申请,我们查看自己的短信模板ID即可
        private int templateId = XXX;
        // 签名,签名参数使用的是`签名内容`,而不是`签名ID`,真实的签名需要在短信控制台申请,这里按自己的来修改就好
        private String smsSign = "XXX";
    }
    

    生成短信验证码工具类

    短信验证码可以是4位或者6位的数字字母组合,我们可以通过下面代码动态的生成短信验证码

    /**
     *  动态生成短信验证码工具类
     */
    public class VerifyCode {
    
        /**
         * 创建指定数量的随机字符串
         * @param isNumber 是否是数字
         * @param length
         * @return
         */
        public static String createRandom(boolean isNumber, int length){
            String resultStr = "";
            String codeContent = isNumber ? "1234567890" : "1234567890abcdefghijkmnpqrstuvwxyz";
            boolean flag = true;
            do {
                int count = 0;
                for (int i = 0; i < length; i++) {
                    double randomCode = Math.random() * codeContent.length();
                    int code = (int) Math.floor(randomCode);
                    char c = codeContent.charAt(code);
                    if (('0' <= c) && (c <= '9')) {
                        count++;
                    }
                    resultStr += codeContent.charAt(code);
                }
                if (count >= 2) {
                    flag = false;
                }
            } while (flag);
            return resultStr;
        }
    }
    

    发送短信

    上面的步骤都完成后,我们就可以发送短信了。下面我就说一下发送短信的步骤

    1. 这里我就直接new一个参数类对象,如果使用springboot的话可以通过依赖注入的方式
    2. 下面的params是为短信模板中的变量复制,也就是我们上面说的{1},{2},...,顺序要对应起来,要不然发送的短信意思可就乱了...
    3. 我的短信模板是有两个变量,一个是验证码,另一个是有效时间,当然变量个数是不限制的
    public class SendMessageTest {
    
        private SMSParameter smsParameter = new SMSParameter();
        
        @Test
        public void testSendMessage(){
            try {
                //短信模板中的参数列表
                String[] params = {VerifyCode.createRandom(true,4),"5"};
                SmsSingleSender sender = new SmsSingleSender(smsParameter.getAppId(), smsParameter.getAppKey());
                SmsSingleSenderResult result = sender.sendWithParam("86", smsParameter.getPhoneNumbers()[0],
                        smsParameter.getTemplateId(), params, smsParameter.getSmsSign(), "", "");
            } catch (HTTPException e) {
                // HTTP 响应码错误
                e.printStackTrace();
            } catch (JSONException e) {
                // JSON 解析错误
                e.printStackTrace();
            } catch (IOException e) {
                // 网络 IO 错误
                e.printStackTrace();
            }
        }
    }
    

    这里给出sendWithParam方法所有参数的说明,哈哈,直接拿官方的来展示...

    在这里插入图片描述
    执行测试,发送短信成功,这样我们就完成了发送短信功能。这样我们就可以在项目中使用短信验证码登录等等...
    下面的9999之前我是固定写的,后来才改为动态生成验证码,因为动态生成的验证码一般不可能是9999,这样的概率太小了。
    在这里插入图片描述

    相关文章

      网友评论

        本文标题:SpringBoot集成腾讯云短信服务发送短信

        本文链接:https://www.haomeiwen.com/subject/xwowdhtx.html