短信验证码实现(阿里云)

如果实现短信验证,上教程,这里用的阿里云短信服务

短信服务 (aliyun.com)

进入短信服务后开通就行,可以体验100条免费,刚好测试用

这里由自定义和专用,测试的话就选择专用吧,自定义要审核,

 SendSms_短信服务_API调试-阿里云OpenAPI开发者门户 (aliyun.com)

这里是方法api,有对应的教程 

验证码模板示例

应用场景模板示例
登录/验证
  • 您的验证码${code},该验证码5分钟内有效,请勿泄漏于他人!
  • 您的验证码:${code},您正进行身份验证,打死不告诉别人!
  • 验证码为:${code},您正在登录,若非本人操作,请勿泄露。
注册
  • 您正在申请手机注册,验证码为:${code},5分钟内有效!
  • 尊敬的用户,您的注册会员动态密码为:${code},请勿泄漏于他人!
  • 您的注册码:${code},如非本人操作,请忽略本短信!
  • 您的校验码:${code},您正在注册成为会员,感谢您的支持!
  • 验证码为:${code},您正在注册成为平台会员,感谢您的支持!
重置密码您的动态码为:${code},您正在进行密码重置操作,如非本人操作,请忽略本短信!
变更信息验证码为:${code},您正在尝试变更重要信息,请妥善保管账户信息。

废话就不说了!

    <!-- 短信依赖 -->
    <dependency>
        <groupId>com.aliyun</groupId>
        <artifactId>dysmsapi20170525</artifactId>
        <version>2.0.24</version>
    </dependency>
package com.xiaoyu;


import com.aliyun.dysmsapi20170525.Client;
import com.aliyun.dysmsapi20170525.models.SendSmsRequest;
import com.aliyun.dysmsapi20170525.models.SendSmsResponse;
import com.aliyun.teaopenapi.models.Config;

import java.util.Random;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class SendSms {
    public static void main(String[] args) throws Exception {

        String phoneNumber = "你的手机号";
        if (isValidPhoneNumber(phoneNumber)) {

            Config config = new Config();
            config.setType("access_key"); // 使用AK初始化凭据客户端,还有其他的STS Token、AK及RamRoleArn、ECS实例RAM角色、OIDCRoleArn、URI凭据、Bearer Token(目前只有云呼叫中心CCC这款产品支持Bearer Token的凭据初始化方式)
            config.setAccessKeyId("你的AccessKey ID"); // AccessKey ID
            config.setAccessKeySecret("你的AccessKey Secret"); // AccessKey Secret
            config.endpoint = "dysmsapi.aliyuncs.com";

            Client client = new Client(config);

            SendSmsRequest request = new SendSmsRequest();
            request.setPhoneNumbers(phoneNumber)
                    .setSignName("阿里云短信测试")//短信签名
                    .setTemplateCode("SMS_154950909")//短信模板
                    .setTemplateParam("{\"code\":" + generateVerificationCode() + "}");
            SendSmsResponse response = client.sendSms(request);
            Integer statusCode = response.getStatusCode();
            System.out.println("状态码:" + statusCode); //打印状态码,200成功
        } else {
            System.out.println("手机号不合法");
        }
    }


    //生成6位数验证码
    private static String generateVerificationCode() {
        Random random = new Random();
        int code = 100000 + random.nextInt(900000); // 生成100000到999999之间的随机数
        return String.valueOf(code);
    }

    //验证手机号
    private static boolean isValidPhoneNumber(String phoneNumber) {
        // 定义中国大陆手机号的正则表达式
        String regex = "^1[3456789]\\d{9}$";
        // 编译正则表达式
        Pattern pattern = Pattern.compile(regex);
        // 创建 Matcher 对象
        Matcher matcher = pattern.matcher(phoneNumber);
        // 进行匹配并返回结果
        return matcher.matches();
    }
}

#这里强调一下,阿里云这里建议使用STS Token比较安全,我这里使用ak初始化非常不安全,不推荐在项目里面这样写

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小雨527

你的鼓励是我的最大的动力!

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

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

打赏作者

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

抵扣说明:

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

余额充值