热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

java短信验证码获取次数限制实例

这篇文章主要介绍了java短信验证码获取次数限制实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

现在不管什么项目,用到短信验证功能,都会在程序上设计一个短信验证码的获取次数限制,这样主要是避免短信验证码接口被刷。

前一段正好做一个项目的用户短信验证码登录功能,就研究了以下,下面贴出来分享一下。

这里涉及到的短信接口,用的第三方短信接口—动力思维思维乐信的(http://www.lx598.com/),如果想了解短信接口接入,可以到他们官网,查看下短信接口API文档说明,参考下面的代码应该就能弄明白。

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

//主要js方法:

//获取手机验证码:

function getRegCode() {
    if($.trim($('#inputCaptcha').val()) == ''){
       $('#imgRs').html("图形验证码不能为空");
       $('#inputCaptcha').select();
       return;
     }
    
    if (!isPhoneNum($('#phoneRe').val())) {
      document.getElementById('phoneReInfo').innerHTML = '请填写有效的11位手机号码';
    } 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 = '该手机号已被注册';
            refreshYzm();
          } else {
            document.getElementById('phoneReInfo').innerHTML = '该手机号可用';
            $.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 = '验证码已发送,请注意查收!
                  accountFID = myArray[1];
                  }else if(data == '限制申请'){
                  document.getElementById('phoneReInfo').innerHTML = '一个手机号码一天最多只能申请3次!';
                  refreshYzm();
                }else if(data == '验证码错误'){
                  document.getElementById('phoneReInfo').innerHTML = '验证码错误!';
                  refreshYzm();
                }
              },
              error : function() {
                alert('异常,内部验证出错!'+data);
              }
            });

          }
        },
              error : function() {
              alert('异常,验证出错!');
            }
          });
    }
    var smsCount=parseInt($('#smsCount').val());
    smsCount=smsCount<3&#63;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 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 acList = new ArrayList();
          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&#63;");
          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;
        }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
  • 本文介绍了DataTables插件的官方网站以及其基本特点和使用方法,包括分页处理、数据过滤、数据排序、数据类型检测、列宽度自动适应、CSS定制样式、隐藏列等功能。同时还介绍了其易用性、可扩展性和灵活性,以及国际化和动态创建表格的功能。此外,还提供了参数初始化和延迟加载的示例代码。 ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
  • 工作经验谈之-让百度地图API调用数据库内容 及详解
    这段时间,所在项目中要用到的一个模块,就是让数据库中的内容在百度地图上展现出来,如经纬度。主要实现以下几点功能:1.读取数据库中的经纬度值在百度上标注出来。2.点击标注弹出对应信息。3 ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 前言:关于跨域CORS1.没有跨域时,ajax默认是带cookie的2.跨域时,两种解决方案:1)服务器端在filter中配置详情:http:blog.csdn.netwzl002 ... [详细]
  • 本文介绍了使用FormData对象上传文件同时附带其他参数的方法。通过创建一个表单,将文件和参数添加到FormData对象中,然后使用ajax发送POST请求进行文件上传。在发送请求时,需要设置processData为false,告诉jquery不要处理发送的数据;同时设置contentType为false,告诉jquery不要设置content-Type请求头。 ... [详细]
  • 查询单个functionquery(id){$.ajax({url:smallproductServlet,async:true,type:POST,data:{typ ... [详细]
  • 比如,我在数据库的num=1,我在页面上显示了1,但是我现在把数据库的num=2,那么怎么实现到那个网页无刷新的更新2了。求大神,最好有个例子,ajax的方法 ... [详细]
  • 我将SpringMVC升级到Spring3.2.5.我的一些剩余调用即使存在,也会返回无法识别的字段异常.这是错误.Resolvingexceptionfrom ... [详细]
author-avatar
545229628_efb16a
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有