您好,登錄后才能下訂單哦!
通過第三方接口發(fā)送短信驗證碼/短信通知
需求:將首次交付密碼為公共默認密碼的方式改為點擊入職功能,用短信方式發(fā)送系統(tǒng)自動生成的八位含數(shù)字、大小寫字母和特殊符號生成的密碼。短信發(fā)送服務(wù)由云通信http://www.yuntongxun.com/提供。
隨機密碼生成方法:
/** * 生成隨即密碼 * @author chao.gao * @param pwd_len 生成的密碼的總長度 * @return 密碼的字符串 */ public static String genRandomNum(int pwd_len) { // String re="(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[!@#$%^&]).{10,}"; String regex = "^(?![0-9]+$)(?![a-zA-Z]+$)[A-Za-z0-9@#$%]{8,16}$"; //35是因為數(shù)組是從0開始的,26個字母+10個數(shù)字 final int maxNum = 26; int i; //生成的隨機數(shù) int count = 0; //生成的密碼的長度 char[] str = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}; char[] upChar = {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'}; char[] numChar = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'}; char[] speChar = {'!', '@', '#', '$', '%'}; StringBuffer pwd = new StringBuffer(""); Random r = new Random(); while (count < 2) { //生成隨機數(shù),取絕對值,防止生成負數(shù), i = Math.abs(r.nextInt(maxNum)); //生成的數(shù)最大為36-1 if (i >= 0 && i < str.length) { pwd.append(str[i]); count++; } } count=0; while (count < 2) { //生成隨機數(shù),取絕對值,防止生成負數(shù), i = Math.abs(r.nextInt(7)); //生成的數(shù)最大為7-1 if (i >= 0 && i < upChar.length) { pwd.append(upChar[i]); count++; } } count=0; while (count < 2) { //生成隨機數(shù),取絕對值,防止生成負數(shù), i = Math.abs(r.nextInt(maxNum)); //生成的數(shù)最大為10-1 if (i >= 0 && i < numChar.length) { pwd.append(numChar[i]); count++; } } count=0; while (count < 2) { //生成隨機數(shù),取絕對值,防止生成負數(shù), i = Math.abs(r.nextInt(maxNum)); //生成的數(shù)最大為10-1 if (i >= 0 && i < speChar.length) { pwd.append(speChar[i]); count++; } } return pwd.toString(); }
發(fā)送短信接口:(jar包見附件)
參考:
https://www.yuntongxun.com/doc/rest/sms/3_2_2_3.html
public class SDKTestSendTemplateSMS { public static void main(String[] args) { HashMap<String, Object> result = null; CCPRestSDK restAPI = new CCPRestSDK(); restAPI.init("app.cloopen.com", "8883"); // 初始化服務(wù)器地址和端口,生產(chǎn)環(huán)境配置成app.cloopen.com,端口是8883. restAPI.setAccount("accountSid", "accountToken"); // 初始化主賬號名稱和主賬號令牌,登陸云通訊網(wǎng)站后,可在"控制臺-應(yīng)用"中看到開發(fā)者主賬號ACCOUNT SID和 主賬號令牌AUTH TOKEN。 restAPI.setAppId("AppId"); // 初始化應(yīng)用ID,如果是在沙盒環(huán)境開發(fā),請配置"控制臺-應(yīng)用-測試DEMO"中的APPID。 //如切換到生產(chǎn)環(huán)境,請使用自己創(chuàng)建應(yīng)用的APPID result = restAPI.sendTemplateSMS("號碼1,號碼2等","模板Id" ,new String[]{"模板內(nèi)容1","模板內(nèi)容2"}); System.out.println("SDKTestGetSubAccounts result=" + result); if("000000".equals(result.get("statusCode"))){ //正常返回輸出data包體信息(map) HashMap<String,Object> data = (HashMap<String, Object>) result.get("data"); Set<String> 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")); } } }
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。