国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

java短信驗證碼獲取次數限制實例

2024-07-13 10:16:02
字體:
來源:轉載
供稿:網友

現在不管什么項目,用到短信驗證功能,都會在程序上設計一個短信驗證碼的獲取次數限制,這樣主要是避免短信驗證碼接口被刷。

前一段正好做一個項目的用戶短信驗證碼登錄功能,就研究了以下,下面貼出來分享一下。

這里涉及到的短信接口,用的第三方短信接口—動力思維思維樂信的(http://www.lx598.com/),如果想了解短信接口接入,可以到他們官網,查看下短信接口API文檔說明,參考下面的代碼應該就能弄明白。

用戶注冊部分,主要代碼如下:

java;">//主要js方法://獲取手機驗證碼: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);  }
// 注冊新用戶// 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 + "");//不是新的一天則次數+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) {            // 這里執行短信發送                        String content = "您的驗證碼為:" + verifyCode+",該碼有效期為24小時,該碼只能使用一次!【短信簽名】";            SendSmsReply sendSmsReply = smsUnit.sendSms(accName,accPwd ,account.getACCMOB(),content,""); //調用第三方接口發送短信            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);      }    }  }
//這是動力思維樂信第三方短信接口的發送短信功能部分參考代碼:/**         * 發送短信         * @param accName 樂信賬號用戶名         * @param accPwd 樂信賬號密碼         * @param seed 當前時間 格式:YYYYMMDD HHMISS 例如:20130806102030         * @param aimcodes 手機號多個手機號之間英文半角逗號隔開         * @param content 內容后加簽名         * @param schTime 定時時間格式如:2010-01-01 08:00:00         * @return 服務端返回的結果 ok:業務id 或者 錯誤代碼         */        public static String sendSms(String accName,String accPwd,String mobies,String content,String schTime){          StringBuffer sb = new StringBuffer("http://sdk.lx198.com/sdk/send2?");          try {            String seed=new SimpleDateFormat(dateFormatStr).format(new Date());            sb.append("&accName="+accName);             sb.append("&seed="+seed);            sb.append("&accPwd="+MD5.getMd5String(MD5.getMd5String(accPwd)+seed));             sb.append("&aimcodes="+mobies);            sb.append("&schTime="+URLEncoder.encode(schTime,"UTF-8")); //空格標點符號做encode轉換            sb.append("&content="+URLEncoder.encode(content,"UTF-8")); //中文做encode轉換            URL url = new URL(sb.toString());            HttpURLConnection connection = (HttpURLConnection) url.openConnection();            connection.setRequestMethod("POST");            BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream()));            return in.readLine();          } catch (Exception e) {            e.printStackTrace();          }          return null;        }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 团风县| 汝阳县| 新密市| 广德县| 晴隆县| 崇左市| 肇东市| 化州市| 区。| 泾源县| 故城县| 明星| 罗定市| 菏泽市| 南汇区| 清远市| 洪湖市| 屏南县| 洛川县| 郯城县| 五常市| 弋阳县| 玉屏| 井研县| 柏乡县| 江阴市| 遵义县| 图木舒克市| 吉水县| 韩城市| 怀仁县| 和硕县| 右玉县| 丹凤县| 壤塘县| 利辛县| 桐梓县| 广灵县| 钟山县| 襄汾县| 昂仁县|