欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java短信驗證碼獲取次數(shù)限制實例

 更新時間:2018年01月05日 16:41:50   作者:韓語  
這篇文章主要介紹了java短信驗證碼獲取次數(shù)限制實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

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

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

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

//主要js方法:

//獲取手機驗證碼:

function getRegCode() {
    if($.trim($('#inputCaptcha').val()) == ''){
       $('#imgRs').html("圖形驗證碼不能為空");
       $('#inputCaptcha').select();
       return;
     }
    
    if (!isPhoneNum($('#phoneRe').val())) {
      document.getElementById('phoneReInfo').innerHTML = '<font color="red">請?zhí)顚懹行У?1位手機號碼</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] == '發(fā)送成功!') {
                  canCaptcha = true;
                  document.getElementById('phoneReInfo').innerHTML = '<font color="green">驗證碼已發(fā)送,請注意查收!</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('異常,內(nèi)部驗證出錯!'+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));//設置使用狀態(tài):未用
        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);
        //驗證碼申請次數(shù)
        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();
          // 通過時間判定申請驗證碼次數(shù)
          //如果是新的一天,則使用次數(shù)改為1
          if (date.getDate() >= ac.getFSECURITYOUTTIME().getDate()) {
            account.setSDKURL("1");
          } else {
            Integer count = Integer.parseInt(ac.getSDKURL());
            account.setSDKURL(count + 1 + "");//不是新的一天則次數(shù)+1
          }
          cishu = Integer.parseInt(account.getSDKURL());
          account.setFSECURITYOUTTIME(c.getTime());
          if (cishu <= 3)
            re = accountService
                .updateByPrimaryKeySelective(account); //使用修改方法保存驗證碼發(fā)送信息
        }

        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) {
            // 這里執(zhí)行短信發(fā)送
            
            String content = "您的驗證碼為:" + verifyCode+",該碼有效期為24小時,該碼只能使用一次!【短信簽名】";
            SendSmsReply sendSmsReply = smsUnit.sendSms(accName,accPwd ,account.getACCMOB(),content,"");
 
//調(diào)用第三方接口發(fā)送短信            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);
      }
    }
  }

//這是動力思維樂信第三方短信接口的發(fā)送短信功能部分參考代碼:

/**
         * 發(fā)送短信
         * @param accName 樂信賬號用戶名
         * @param accPwd 樂信賬號密碼
         * @param seed 當前時間 格式:YYYYMMDD HHMISS 例如:20130806102030
         * @param aimcodes 手機號多個手機號之間英文半角逗號隔開
         * @param content 內(nèi)容后加簽名
         * @param schTime 定時時間格式如:2010-01-01 08:00:00
         * @return 服務端返回的結果 ok:業(yè)務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轉(zhuǎn)換
            sb.append("&content="+URLEncoder.encode(content,"UTF-8")); //中文做encode轉(zhuǎn)換
            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;
        }

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Mybatis批量提交實現(xiàn)步驟詳解

    Mybatis批量提交實現(xiàn)步驟詳解

    這篇文章主要介紹了Mybatis批量提交實現(xiàn)步驟詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-12-12
  • Tk.mybatis零sql語句實現(xiàn)動態(tài)sql查詢的方法(4種)

    Tk.mybatis零sql語句實現(xiàn)動態(tài)sql查詢的方法(4種)

    有時候,查詢數(shù)據(jù)需要根據(jù)條件使用動態(tài)查詢,這時候需要使用動態(tài)sql,本文主要介紹了Tk.mybatis零sql語句實現(xiàn)動態(tài)sql查詢的方法,感興趣的可以了解一下
    2021-12-12
  • 最新評論