java實現註冊的簡訊驗證碼
阿新 • • 發佈:2019-01-08
第三方簡訊介面服務商—動力思維樂信,贈送100條免費測試簡訊。
步驟一、到http://www.lx598.com/ 註冊一個賬號,這個賬號和密碼後期接入過程中要用到。
步驟二、登入賬戶,完善企業資訊,申請sdk使用。
步驟三、閱讀“簡訊介面api”文件,和下載對於開發語言的的麼,下面示例是用java開發語言實現的,就貼出來java的簡訊介面demo(http://www.lx598.com/javaCode.html)
步驟一、到http://www.lx598.com/ 註冊一個賬號,這個賬號和密碼後期接入過程中要用到。
步驟二、登入賬戶,完善企業資訊,申請sdk使用。
步驟三、閱讀“簡訊介面api”文件,和下載對於開發語言的的麼,下面示例是用java開發語言實現的,就貼出來java的簡訊介面demo(http://www.lx598.com/javaCode.html)
1、首先註冊介面基本的資訊都有以下幾點(直接上圖):圖片驗證碼,手機號,密碼,驗證碼幾個基本資訊
2、其次要對手機號進行判斷,是否註冊過,手機號格式是否正確
3、前臺註冊頁面程式碼:
4、下面是實現圖片驗證和傳送簡訊的js程式碼:<div id="con2" height:370px;"> <table width="92%" border="0" align="center" cellspacing="0" style="padding:0px; margin:0px;"> <tbody style="padding:0px; margin:0px;"> <tr height="40"> <td class="reg_left">圖片校驗碼</td> <td width="260px"> <input name="inputCaptcha" id="inputCaptcha" type="text" size="4" class="reg_input"/> </td> <td><img src="${path }/sys/loginCaptcha" id="validImg" onclick="refreshYzm();" /><span id="imgRs" style="color:red;">點選圖片重新整理</span></td> </tr> <tr> <td class="reg_left">手機號碼</td> <td width="260px"><input type="text" name="phoneRe" id="phoneRe" class="reg_input" onchange="resetCount()" /> <input type="hidden" name="smsCount" id="smsCount" value="1"/></td> <td class="reg_xxts"><span id="phoneReInfo"></span></td> </tr> <tr height="40"> <td class="reg_left"></td> <td colspan="2"><a href="javascript:getRegCode();" class="reg_phone">免費獲取驗證碼</a></td> </tr> <tr height="60"> <td class="reg_left">驗證碼</td> <td width="260px"><input type="text" name="regNum" id="regNum" class="reg_input" onblur="lostInput()" /></td> <td class="reg_xxts"><span id="regNumInfo"></span></td> </tr> <tr height="60"> <td class="reg_left">密碼</td> <td><input type="password" name="pass2" id="pass2" class="reg_input" maxlength="16" onKeyUp="pwStrength2(this.value)" onkeydown="pwStrength2(this.value)" /><br/> <table width="250" border="0" cellspacing="1" cellpadding="1" bordercolor="#cccccc" height="25" style="display:inline"> <tr align="center" bgcolor="#eeeeee"> <td width="84px" id="strength_L2">弱</td> <td width="84px" id="strength_M2">中</td> <td width="84px" id="strength_H2">強</td> </tr> </table></td> <td class="reg_xxts"><span id="pass1Info2"></span></td> </tr> <tr height="60"> <td class="reg_left">確認密碼</td> <td><input type="password" name="passRe2" id="passRe2" class="reg_input" maxlength="16" onKeyUp="regiPass(1)" onkeydown="regiPass(1)" /></td> <td class="reg_xxts"><span id="pass2Info2"></span></td> </tr> <tr height="30"> <td> </td> <td class="reg_fwtk"><input type="checkbox" name="agreeCheck2" id="agreeCheck2" checked /> 我已經閱讀並同意《<a href="${webRootPath}/lxfwtk.html" target="_blank">服務條款</a>》</td> <td class="reg_fwtk"> </td> </tr> <tr height="60"> <td> </td> <td><a href="#" target="_self" class="reg_sub" onclick="registerByAimcode()">立即註冊</a></td> <td> </td> </tr> </tbody> </table> </div>
//手機號格式驗證 function isPhoneNum(str) { var reg = /^0?(13[0-9]|15[012356789]|18[012356789]|14[57]|17[0-9]|199)[0-9]{8}$/; return reg.test(str); } //判斷圖形驗證碼填寫是否正確 var canCaptcha = false; function getRegCode() { if($.trim($('#inputCaptcha').val()) == ''){ $('#imgRs').html("圖形驗證碼不能為空"); $('#inputCaptcha').select(); return; } if (!isPhoneNum($('#phoneRe').val())) { document.getElementById('phoneReInfo').innerHTML = '<font color="red">請填寫有效的11位手機號碼</font>'; } else { document.getElementById('phoneReInfo').innerHTML = '註冊後用手機號碼進行登入'; //判斷手機號是否註冊及傳送驗證碼 $.ajax({ url : "${path}/account/checkMob", type : "POST", data : "account.ACCMOB=" + $('#phoneRe').val(), contentType : "application/x-www-form-urlencoded;charset=utf-8", async : false, success : function(data) { res = data; if (data == 1) { document.getElementById('phoneReInfo').innerHTML = '<font color="red">該手機號已被註冊</font>'; refreshYzm(); } else { document.getElementById('phoneReInfo').innerHTML = '<font color="green">該手機號可用</font>'; $.ajax({ url : "${path}/account/reAimcodeGetVeCode", type : "POST", data : "account.ACCMOB=" + $('#phoneRe').val() + "&fromSource=4&smsCount="+$('#smsCount').val() +"&searchName="+$.trim($('#inputCaptcha').val()), contentType : "application/x-www-form-urlencoded;charset=utf-8", async : false, success : function(data) { myArray = data.split("&"); if (myArray[0] == '傳送成功!') { canCaptcha = true; document.getElementById('phoneReInfo').innerHTML = '<font color="green">驗證碼已傳送,請注意查收!</font>'; accountFID = myArray[1]; }else if(data == '限制申請'){ document.getElementById('phoneReInfo').innerHTML = '<font color="red">一個手機號碼一天最多隻能申請3次!</font>'; refreshYzm(); }else if(data == '驗證碼錯誤'){ document.getElementById('phoneReInfo').innerHTML = '<font color="red">驗證碼錯誤!</font>'; refreshYzm(); } }, error : function() { alert('異常,內部驗證出錯!'+data); } }); } }, error : function() { alert('異常,驗證出錯!'); } }); } //驗證碼申請次數 var smsCount=parseInt($('#smsCount').val()); smsCount=smsCount<3?smsCount+1:3; $('#smsCount').val(smsCount); } //重置申請次數 function resetCount(){ $('#smsCount').val(1); } //點選重新整理圖片驗證碼 function refreshYzm(){ $('#inputCaptcha').val(''); $('#validImg').attr('src','${path }/sys/loginCaptcha?tm='+Math.random()); } //密碼強度檢測 function CharMode(iN) { if (iN >= 48 && iN <= 57) //數字 return 1; if (iN >= 65 && iN <= 90) //大寫字母 return 2; if (iN >= 97 && iN <= 122) //小寫 return 4; else return 8; //特殊字元 } //計算出當前密碼當中一共有多少種模式 function bitTotal(num) { modes = 0; for ( var i = 0; i < 4; i++) { if (num & 1) modes++; num >>>= 1; } return modes; } //checkStrong函式 //返回密碼的強度級別 function checkStrong(sPW) { if (sPW.length <= 4) return 0; //密碼太短 Modes = 0; for ( var i = 0; i < sPW.length; i++) { //測試每一個字元的類別並統計一共有多少種模式 Modes |= CharMode(sPW.charCodeAt(i)); } return bitTotal(Modes); } //pwStrength函式 //當用戶放開鍵盤或密碼輸入框失去焦點時,根據不同的級別顯示不同的顏色 function pwStrength(pwd) { checkPassLong(0); var O_color = "#eeeeee"; var L_color = "#FF0000"; var M_color = "#FF9900"; var H_color = "#33CC00"; if (pwd == null || pwd == '') { Lcolor = Mcolor = Hcolor = O_color; } else { var S_level = checkStrong(pwd); switch (S_level) { case 0: Lcolor = Mcolor = Hcolor = O_color; case 1: Lcolor = L_color; Mcolor = Hcolor = O_color; break; case 2: Lcolor = Mcolor = M_color; Hcolor = O_color; break; default: Lcolor = Mcolor = Hcolor = H_color; } } document.getElementById("strength_L").style.background = Lcolor; document.getElementById("strength_M").style.background = Mcolor; document.getElementById("strength_H").style.background = Hcolor; return; } function pwStrength2(pwd) { checkPassLong(1); var O_color = "#eeeeee"; var L_color = "#FF0000"; var M_color = "#FF9900"; var H_color = "#33CC00"; if (pwd == null || pwd == '') { Lcolor = Mcolor = Hcolor = O_color; } else { var S_level = checkStrong(pwd); switch (S_level) { case 0: Lcolor = Mcolor = Hcolor = O_color; case 1: Lcolor = L_color; Mcolor = Hcolor = O_color; break; case 2: Lcolor = Mcolor = M_color; Hcolor = O_color; break; default: Lcolor = Mcolor = Hcolor = H_color; } } document.getElementById("strength_L2").style.background = Lcolor; document.getElementById("strength_M2").style.background = Mcolor; document.getElementById("strength_H2").style.background = Hcolor; return; } function checkPassLong(flag) { var passStr = $('#pass').val(); if (flag == 1) { passStr = $('#pass2').val(); } passStr = passStr.replace(/(\s*$)/g, ""); if (passStr.length == 0 || passStr.length < 6) { if (flag == 0) { document.getElementById('pass1Info').innerHTML = '<font color="red">密碼長度大於6位,不能為空格</font>'; } else { document.getElementById('pass1Info2').innerHTML = '<font color="red">密碼長度大於6位,不能為空格</font>'; } return true; } else { if (flag == 0) { document.getElementById('pass1Info').innerHTML = '由6-16位字元組成,請使用英文字母、符號或數字。'; } else { document.getElementById('pass1Info2').innerHTML = '由6-16位字元組成,請使用英文字母、符號或數字。'; } return false; } } //密碼強度驗證end 5、後臺action方法,Account為使用者類 // 註冊新使用者 @Action(value = "reAimcodeGetVeCode") public void reAimcodeGetVeCode() { PrintWriter out; String result = "驗證碼申請失敗!請重試!"; try { smsUnit = new SmsUnit(ConfUtil.getProperty("sys_sms_server")); if (null != account.getACCMOB() && !account.getACCMOB().equals("")) { account.setACCSTATUS(new BigDecimal(1));//設定使用狀態未用 String verifyCode = String .valueOf(new Random().nextInt(899999) + 100000);//生成簡訊驗證碼 account.setFSECURITYCODE(verifyCode); account.setACCCREATEDATE(new Date()); Calendar c = Calendar.getInstance(); c.add(Calendar.DAY_OF_MONTH, 1); // 設定驗證碼失效時間為24小時 account.setFREGISTERSOURCE(fromSource); // 判斷該手機是否獲取過驗證碼 AccountCriteria accountCriteria = new AccountCriteria(); accountCriteria.createCriteria().andACCMOBEqualTo( account.getACCMOB()); List<Account> accs = accountService .selectByExample(accountCriteria); int re = 0; Integer cishu = 0; if (accs == null || accs.isEmpty()) { cishu = 1; account.setSDKURL("1"); account.setFSECURITYOUTTIME(c.getTime()); BigDecimal accid=accountService.getPrimaryKey(); account.setFID(accid); re = accountService.insertSelective(account,IPUtil.getRealIP(request)); Cookie cookie=new Cookie("id" , accid.toString()); cookie.setMaxAge(Integer.MAX_VALUE); response.addCookie(cookie); } else { Account ac = accs.get(0); account.setFID(ac.getFID()); Date date = new Date(); // 如果是新的一天則使用次數修改為1 if (date.getDate() == ac.getFSECURITYOUTTIME().getDate()) { account.setSDKURL("1"); } else { Integer count = Integer.parseInt(ac.getSDKURL()); account.setSDKURL(count + 1 + ""); } cishu = Integer.parseInt(account.getSDKURL()); account.setFSECURITYOUTTIME(c.getTime()); if (cishu <= 3) re = accountService .updateByPrimaryKeySelective(account); } if (re > 0 && cishu <= 3) { request.getSession().removeAttribute(ConstValues.WEB_SESSION_PROMOTE); AccountCriteria ac = new AccountCriteria(); ac.createCriteria().andACCMOBEqualTo(account.getACCMOB()); List<Account> acList = new ArrayList<Account>(); acList = accountService.selectByExample(ac); if (acList != null && acList.size() > 0) { // 這裡執行簡訊傳送 DateFormat df = new SimpleDateFormat("yyyyMMddhhmmss"); String bizID = df.format(new Date()); SendSmsReply sendSmsReply = smsUnit.sendSms("","","您的驗證碼為:" + verifyCode+",該碼有效期為24小時, 該碼只能使用一次!【簡訊簽名】", bizID,account.getACCMOB(), "", 1 + "", 1 + "","","","" , ""); result = sendSmsReply.getReplyMsg() + "&" + acList.get(0).getFID() + "&" + acList.get(0).getSDKURL(); } } else if (cishu > 3) { result = "限制申請"; } } } catch (Exception e) { logger.error("獲取驗證碼失敗", e); } finally { try { response.setContentType("text/html;charset=UTF-8"); response.setCharacterEncoding("UTF-8"); out = response.getWriter(); out.write(result); } catch (IOException e) { logger.error("", e); } } } SmsUnit簡訊傳送類程式碼: // 傳送簡訊 public SendSmsReply sendSms(String acname, String acpwdmd5, String smsContent, String batchnumber, String mobiles, String schTime, String serialPkgNumber, String countPkgNum, String sendType,String pid,String reno) { httppost = new HttpPost("www.lx198.com/lxDlsms/sms/sendSms"); List<NameValuePair> formparams = new ArrayList<NameValuePair>(); formparams.add(new BasicNameValuePair("sendSms.acName", acname));// 使用者名稱 formparams.add(new BasicNameValuePair("sendSms.pwd", acpwdmd5));// 密碼 formparams .add(new BasicNameValuePair("sendSms.smsContent", smsContent));// 簡訊內容 formparams.add(new BasicNameValuePair("sendSms.mobiles", mobiles));// 電話號碼 formparams.add(new BasicNameValuePair("sendSms.schTime", schTime)); formparams.add(new BasicNameValuePair("sendSms.batchNum", batchnumber)); formparams.add(new BasicNameValuePair("sendSms.pkgNum", serialPkgNumber)); formparams.add(new BasicNameValuePair("sendSms.pkgCount", countPkgNum)); formparams.add(new BasicNameValuePair("sendSms.sendType", sendType)); formparams.add(new BasicNameValuePair("sendSms.pid", pid)); formparams.add(new BasicNameValuePair("sendSms.reno", reno)); //private String reno=""; try { String replyString = doPost(formparams); return (SendSmsReply) XmlReplyUnit.fromXml(replyString,new SendSmsReply()); } catch (ParseException e) { logger.error("",e); } catch (Exception e) { logger.error("",e); } return null; }