1.登录容联云官网https://www.yuntongxun.com
2. 按照提示注册一个容联云账号
3. 注册完成点击控制台如下页面
需要记住:ACCOUNT SID,AUTH TOKEN,AppID,后面的程序中会用到
4.点击左侧应用管理,点击创建应用
5,点击编辑,勾选短信验证码,短信通知即可
6,点击测试号码,填写自己的手机号即可,到此容联云工作基本完成
可以参考容联云主页 ➡️ 开发文档 ➡️ 短信开发手册 里面有关于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程序还需要根据我们设置的过期时间进行比较校验