java限制短信验证码的次数(实例分享)

前两天分享了怎么用java去接入短信,今天正好做好新的功能,有的用户收不到短信,就一直点重新发,其实可能是自己手机的问题,这个时候我们就需要限制用户发送短信了,当然这个功能也用于恶意被刷短信,恶意被刷短信会导致企业的短信消耗特别大,所以这个功能配合图形验证码功能是非常有必要的。

这里涉及到的短信接口,用的第三方短信接口—互亿无线的(www.ihuyi.com),如果想了解短信接口接入,可以到他们官网,查看下短信接口API文档说明,参考下面的代码应该就能弄明白。

用户注册部分,主要代码如下:

/

/主要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;

        }

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,919评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,567评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,316评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,294评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,318评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,245评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,120评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,964评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,376评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,592评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,764评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,460评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,070评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,697评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,846评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,819评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,665评论 2 354

推荐阅读更多精彩内容