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 = '<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;
        }

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

您可能感兴趣的文章:

  • java接入创蓝253短信验证码的实例讲解
  • Java实现发送短信验证码功能
  • Java实现短信验证码和国际短信群发功能的示例
  • JAVA实现利用第三方平台发送短信验证码
  • 基于JAVA的短信验证码api调用代码实例
  • Java随机生成手机短信验证码的方法
(0)

相关推荐

  • JAVA实现利用第三方平台发送短信验证码

    前段时间自己做的一个小项目中,涉及到用短信验证码登录.注册的问题,之前没涉及过这一块,看了别人的博客其实也是似懂非懂的,现在就将自己做的利用第三方短信平台来发送验证码这个功能记下来. 本文以注册为例,在SpringMVC+Spring+Mybatis框架的基础上完成该短信验证码功能. 发送短信验证码的原理是:随机生成一个6位数字,将该6位数字保存到session当中,客户端通过sessionid判断对应的session,用户输入的验证码再与session记录的验证码进行比较. 为了防止有广告嫌疑

  • Java实现短信验证码和国际短信群发功能的示例

    最近由于公司的业务拓展,需要给国外用户发送国际短信,像西班牙.葡萄牙.意大利这些国家都要发,还有中国的香港.澳门.台湾(港澳台)这些地区也要发,不过现在已经有许多公司提供国际短信的业务了,之前使用过云片的验证码业务,顺便看到他们也有国际短信的业务,并且更重要的是,不需要修改任何代码,只要添加下国际短信模板,就可以直接使用之前的代码继续发送国际短信,简直太方便了. 废话不多说,直接上代码. /** * Created by bingone on 15/12/16. */ import org.ap

  • Java随机生成手机短信验证码的方法

    本文实例讲述了Java随机生成手机短信验证码的方法.分享给大家供大家参考,具体如下: /** * 创建指定数量的随机字符串 * @param numberFlag 是否是数字 * @param length * @return */ public static String createRandom(boolean numberFlag, int length){ String retStr = ""; String strTable = numberFlag ? "1234

  • java接入创蓝253短信验证码的实例讲解

    说明 项目是springboot框架 1.短信配置文件 包含验证码发送路径.用户名.密码 chuanglan.requesturl= chuanglan.account= chuanglan.pswd= 配置文件 具体值 查看官网 位置查看截图 红框已经标红 2.读取配置文件类 3.发送数据request实体类 public class SmsVariableRequest { private String account; private String password; private St

  • Java实现发送短信验证码功能

    一个发送短信验证码的功能,使用的是信易通的短信平台接口,然后在Java中使用HttpClient模拟POST请求或者GET请求(看短信平台要求,一般的情况下都是POST请求),调用短信平台提供的接口(遵循短信平台的接口规范即可).具体看代码: 使用HttpClient的时候需要在项目中引入: commons-httpclient-3.1.jar 这个jar包, 项目结构: 1.创建一个Http的模拟请求工具类,然后写一个POST方法或者GET方法 /** * 文件说明 * @Descriptio

  • 基于JAVA的短信验证码api调用代码实例

    本文实例为大家分享了JAVA的短信验证码api调用代码,供大家参考,具体内容如下 import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.UnsupportedEncodingException; import jav

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

    现在不管什么项目,用到短信验证功能,都会在程序上设计一个短信验证码的获取次数限制,这样主要是避免短信验证码接口被刷. 前一段正好做一个项目的用户短信验证码登录功能,就研究了以下,下面贴出来分享一下. 这里涉及到的短信接口,用的第三方短信接口-动力思维思维乐信的(http://www.lx598.com/),如果想了解短信接口接入,可以到他们官网,查看下短信接口API文档说明,参考下面的代码应该就能弄明白. 用户注册部分,主要代码如下: //主要js方法: //获取手机验证码: function

  • php实现对短信验证码发送次数的限制实例讲解

    场景 在注册,修改密码,找回密码等场景里,我们都会遇到发送手机短信进行验证码验证,我们都知道,手机的这个短信接口是需要购买了,为了防刷,我们就会对短信验证码发送次数的限制,我们应该如何防止呢? 很多人都会这样做:对用户获取短信验证码的手机号.ip.和浏览器(使用唯一标识)进行限制. 本文介绍的方法是对用户每天只能通过同一浏览器或同一ip地址获取验证码10次或者同一手机号只能获取3次短信验证码,三种限制为"或"关系,一条超限就不发验证码.方法是通过在服务器端将用户的手机号.ip.ur_r

  • 基于PHP实现短信验证码发送次数限制

    对用户获取短信验证码的手机号.ip.和浏览器(使用唯一标识)进行限制.本文介绍的方法是对用户每天只能通过同一浏览器或同一ip地址获取验证码10次或者同一手机号只能获取3次短信验证码,三种限制为"或"关系,一条超限就不发验证码.方法是通过在服务器端将用户的手机号.ip.ur_r记录并写入文件,再通过读取文件记录判断用户请求发送验证码的次数来做限制.方法如下: 获取短信验证码页面: <!DOCTYPE html> <html> <head></he

  • java短信验证码登录功能设计与实现

    目录 前言 业务案例 业务关键点剖析 短信验证码功能实现思路 有效期问题 操作步骤 前言 现在不管是各类的网站,还是大小社交app,登录方式是越来越多了,其中基于短信验证码的登录可以说是各类app必不可少的方式,短信验证码登录以其高效,安全,便捷等特性受到许多用户的青睐 业务案例 如下所示,是一个大家熟知的采用短信登录的入口 输入手机号之后,出现如下效果, 输入手机上面收到的验证码之后,就可以正常登录了 业务关键点剖析 以上是一个正常的使用短信验证码登录的业务流程,在实际开发中,需要考虑的因素更

  • Flutter之Timer实现短信验证码获取60s倒计时功能的代码

    先看下效果: 两种需求场景: 1.广告页3s后跳转到首页 2.短信验证码60s倒计时 第一种的话,根据需求我们可以知道,我们想要的效果就是3s结束做出一个动作. factory Timer(Duration duration, void callback()) { if (Zone.current == Zone.root) { // No need to bind the callback. We know that the root's timer will // be invoked in

  • Android实现短信验证码获取自动填写功能(详细版)

    现在的应用在注册登录或者修改密码中都用到了短信验证码,那在android中是如何实现获取短信验证码并自动填写的呢? 首先,需要要在manifest中注册接收和读取短信的权限: <uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission> <uses-permission android:name="android.permission.READ_

  • Java实现发送短信验证码+redis限制发送的次数功能

    java实现短信验证码发送,由于我们使用第三方平台进行验证码的发送,所以首先,我们要在一个平台进行注册.这样的平台有很多,有的平台在新建账号的时候会附带赠几条免费短信.这里我仅做测试使用(具体哪个平台见参考三,很简单,注册账号就行,记得添加短信签名). 另外,在实际项目中,如果有人恶意攻击,不停的发送短信验证码,就会造成很大的损失.故对发送次数做一定的限制就非常必要,这里我们限制一个手机号一天可以发多少短信和短信平台无关. 这里采用的是存redis来实现这一个功能.就是每次调用发送验证码这个接口

  • Java实现短信验证码的示例代码

    目录 项目需求 需求来由 代码实现 发送验证码方法 注册方法 忘记密码 前端代码 编码中遇到的问题 如何改进 短信验证码相信大家都不陌生吗,但是短信验证码怎么生成的你真的了解吗,本文揭示本人项目中对短信验证码的. 项目需求 用户注册/忘记密码添加短信验证码 需求来由 登录注册页面需要确保用户同一个手机号只关联一个账号确保非人为操作,避免系统用户信息紊乱增加系统安全性 代码实现 同事提供了WebService接口,很好,之前没调过,又增加了困难. 这边用的阿里云的短信服务,废话少说上图,呸,上代码

  • Android实现获取短信验证码并自动填写功能

    本文实例为大家分享了Android短信验证码获取并自动填写功能的具体代码,供大家参考,具体内容如下 代码如下: MainActivity public class MainActivity extends AppCompatActivity { public static TextView mText; private SmsContent content; @Override protected void onCreate(Bundle savedInstanceState) { super.

随机推荐