SpringBoot集成阿里云短信验证码服务

一:前言

最近在项目开发过程中,需要去写一个发送手机短信验证码的功能。在网上查了一下,有很多服务器可供选择,本文的话是基于阿里云服务的短信验证码功能实现。

关于注册和开通服务这些需要操作的,请各位小伙伴参考官方文档:

使用OpenAPI调试短信服务_短信服务(SMS)-阿里云帮助中心使用OpenAPI自动化集成短信服务,可以提升您使用短信服务的开发效率。本文介绍使用OpenAPI调试短信服务的基本信息及注意事项。https://help.aliyun.com/zh/sms/developer-reference/using-openapi?spm=a2c4g.11186623.0.i1 开通完成后,我们至少需要下图中的四个字段,这里我罗列出来,缺少这些东西的小伙伴请根据文档来补全。

二:代码

1、导入依赖

在 SpringBoot项目中的 pom.xml 文件中导入依赖

java 复制代码
        <!-- 集成阿里云短信服务 -->
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>dysmsapi20170525</artifactId>
            <version>2.0.24</version>
        </dependency>

2、创建变量

为了数据的安全,防止攻击,我们可以进入 application.yml 文件配置全局变量,我这里的缩进如下:

3、实现代码

1)在 Controller 中获取到这些变量

java 复制代码
    @Value("${sofast.password.smsCode.accessKeyId}")
    private String accessKeyId;
    @Value("${sofast.password.smsCode.accessKeySecret}")
    private String accessKeySecret;
    @Value("${sofast.password.smsCode.signName}")
    private String signName;
    @Value("${sofast.password.smsCode.templateCode}")
    private String templateCode;

2)这里我们来写两个前置方法

生成四位随机数的方法,非常简单,可以根据自己的需求和短信模板进行修改。

java 复制代码
    public static String generateCode() {
        Random random = new Random();
        int code = random.nextInt(9000) + 1000;
        return String.valueOf(code);
    }

初始化账号的方法,这个是直接从官网上拿过来的

java 复制代码
    public com.aliyun.dysmsapi20170525.Client createClient() throws Exception {
        // 工程代码泄露可能会导致 AccessKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考。
        // 建议使用更安全的 STS 方式,更多鉴权访问方式请参见:https://help.aliyun.com/document_detail/378657.html。
        com.aliyun.teaopenapi.models.Config config = new com.aliyun.teaopenapi.models.Config()
            // 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_ID。
            .setAccessKeyId(accessKeyId)
            // 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
            .setAccessKeySecret(accessKeySecret);
        // Endpoint 请参考 https://api.aliyun.com/product/Dysmsapi
        config.endpoint = "dysmsapi.aliyuncs.com";
        return new com.aliyun.dysmsapi20170525.Client(config);
    }

3)接口主方法

这个是方法的主要执行体,我们定义了一个接口,后续直接往这个接口传一个手机号的字符串就行了,要注意的是,我们可以不在这里进行手机号格式的判断,因为在阿里云服务器端,会进行判断,图省事的小伙伴可以直接将返回的提示传给前端就可以啦!

java 复制代码
@GetMapping("/verification/sendSmsCode/{phone}")
    @DynamicDS(value = DataSourceType.SLAVE)
    @ApiOperation("发送短信验证码")
    public R  sendSmsCode(@PathVariable("phone") @NotNull String phone) throws Exception {
        String code = generateCode();
        SendSmsResponse sendSmsResponse = new SendSmsResponse();
        com.aliyun.dysmsapi20170525.Client client = createClient();
        com.aliyun.dysmsapi20170525.models.SendSmsRequest sendSmsRequest = new com.aliyun.dysmsapi20170525.models.SendSmsRequest()
            .setPhoneNumbers(phone)
            .setSignName(signName)
            .setTemplateCode(templateCode)
            .setTemplateParam("{\"code\":\""+code+"\"}");
        try {
            // 复制代码运行请自行打印 API 的返回值
            sendSmsResponse = client.sendSmsWithOptions(sendSmsRequest, new RuntimeOptions());
        } catch (TeaException error) {
            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
            // 错误 message
            System.out.println(error.getMessage());
            // 诊断地址
            System.out.println(error.getData().get("Recommend"));
            com.aliyun.teautil.Common.assertAsString(error.message);
        } catch (Exception _error) {
            TeaException error = new TeaException(_error.getMessage(), _error);
            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
            // 错误 message
            System.out.println(error.getMessage());
            // 诊断地址
            System.out.println(error.getData().get("Recommend"));
            com.aliyun.teautil.Common.assertAsString(error.message);
        }
        return R.data(sendSmsResponse.body.message);
    }

4、效果

接口返回值:

手机收到的短信:

三:结尾

上述是SpringBoot集成阿里云短信服务的详细代码,其实现逻辑是非常简单的,当然比较繁琐的一块在服务的开通,模板的定义这里。不过按照官方文档一步一步来,大多数的小伙伴都是没问题的,因此本文不再赘述。好啦,希望能够对各位小伙伴有所帮助哦!

相关推荐
tuan_zhang12 小时前
第七章:未名湖畔的樱花网关
程序人生·云计算
weixin_4180076012 小时前
MQTTX连接阿里云的物联网配置
物联网·阿里云·云计算
BOB-wangbaohai13 小时前
阿里云ACP云计算备考笔记 (4)——企业应用服务
阿里云·云计算·云监控·云解析·云cdn·sls日志服务
亚林瓜子18 小时前
AWS API Gateway配置日志
云计算·gateway·aws·log·cloudwatch
CRMEB定制开发20 小时前
CRMEB 中 PHP 快递查询扩展实现:涵盖一号通、阿里云、腾讯云
阿里云·php·腾讯云·商城系统·商城源码
家庭云计算专家21 小时前
飞牛云一键设置动态域名+ipv6内网直通访问内网的ssh服务-家庭云计算专家
运维·云计算·ssh·nextcloud·ddns·动态域名解析
Johny_Zhao1 天前
华为MAAS、阿里云PAI、亚马逊AWS SageMaker、微软Azure ML各大模型深度分析对比
linux·人工智能·ai·信息安全·云计算·系统运维
Wish3D1 天前
阿里云OSS 上传文件 Python版本
开发语言·python·阿里云
success_a1 天前
大故障:阿里云核心域名爆炸了
数据库·阿里云·云计算
CRMEB定制开发2 天前
CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云
阿里云·php·腾讯云·微信商城·php商城源码