Java实现短信验证码功能(利用容联云,个人测试,不需要项目上线)

前提:

开发环境:jdk1.8 + idea2020

准备工作:

1.登录容联云官网https://www.yuntongxun.com

2. 按照提示注册一个容联云账号

3. 注册完成点击控制台如下页面

需要记住:ACCOUNT SID,AUTH TOKEN,AppID,后面的程序中会用到

Java实现短信验证码功能(利用容联云,个人测试,不需要项目上线)_第1张图片

4.点击左侧应用管理,点击创建应用

Java实现短信验证码功能(利用容联云,个人测试,不需要项目上线)_第2张图片

5,点击编辑,勾选短信验证码,短信通知即可

Java实现短信验证码功能(利用容联云,个人测试,不需要项目上线)_第3张图片

6,点击测试号码,填写自己的手机号即可,到此容联云工作基本完成

Java实现短信验证码功能(利用容联云,个人测试,不需要项目上线)_第4张图片

Java代码:

可以参考容联云主页   ➡️  开发文档  ➡️   短信开发手册 里面有关于java开发的代码

我的java程序如下:

1. 利用maven导入依赖

   
        
            com.cloopen
            java-sms-sdk
            1.0.4
        
    

2.

package com.amazon.platform.common.utils;
import com.cloopen.rest.sdk.BodyType;
import com.cloopen.rest.sdk.CCPRestSmsSDK;
import java.util.HashMap;
import java.util.Set;

public class AuthCodeUtil {
    public static void main(String[] args) {
        authCode("前端输入的手机号");
    }


    public static void authCode(String phoneNumber){

        //生产环境请求地址:app.cloopen.com
        String serverIp = "app.cloopen.com";
        //请求端口
        String serverPort = "8883";
        //主账号,登陆云通讯网站后,可在控制台首页看到开发者主账号ACCOUNT SID和主账号令牌AUTH TOKEN
        String accountSId = "输入你账户里面的ACCOUNT SId";
        String accountToken = "主账号令牌AUTH TOKEN";
        //请使用管理控制台中已创建应用的APPID
        String appId = "管理控制台中已创建应用的APPID";
        CCPRestSmsSDK sdk = new CCPRestSmsSDK();
        sdk.init(serverIp, serverPort);
        sdk.setAccount(accountSId, accountToken);
        sdk.setAppId(appId);
        sdk.setBodyType(BodyType.Type_JSON);
        //随机生成6位数字验证码
        String code = String.valueOf(Math.random()).substring(2, 8);
        System.out.println("随机生成的6位验证码是: " + code);
        String to = phoneNumber;
        String templateId= "1";
        String[] datas = {code,"10"};
//        String subAppend="1234";  //可选 扩展码,四位数字 0~9999
//        String reqId="fadfafas";  //可选 第三方自定义消息id,最大支持32位英文数字,同账号下同一自然天内不允许重复
        //HashMap result = sdk.sendTemplateSMS(to,templateId,datas);
        HashMap result = sdk.sendTemplateSMS(to,templateId,datas);
        if("000000".equals(result.get("statusCode"))){
            //正常返回输出data包体信息(map)
            HashMap data = (HashMap) result.get("data");
            Set keySet = data.keySet();
            for(String key:keySet){
                Object object = data.get(key);
                System.out.println(key +" = "+object);
            }
        }else{
            //异常返回输出错误码和错误信息
            System.out.println("错误码=" + result.get("statusCode") +" 错误信息= "+result.get("statusMsg"));
        }

    }
}

3.注意:这里的String templateId= "1";是我使用的模版是1,你可以根据自己的需要进行更改,里面的code随机验证码,10代表,有效期10分钟

String templateId= "1";
String[] datas = {code,"10"};

4.这段代码代表随机生成6位验证码,自己可以根据需要进行更改

//随机生成6位数字验证码
        String code = String.valueOf(Math.random()).substring(2, 8);
        System.out.println("随机生成的6位验证码是: " + code);

总结:

个人理解:第三方短信验证码逻辑:

java程序生成验证码(4位,6位等等)-> 第三方平台 -> 发送短信给手机 -> 然后前段用户输入验证码 -> java程序进行校验

java程序还需要根据我们设置的过期时间进行比较校验

 

 

你可能感兴趣的:(java)