java短信验证码获取次数限制实例
程序员文章站
2023-12-19 14:56:28
现在不管什么项目,用到短信验证功能,都会在程序上设计一个短信验证码的获取次数限制,这样主要是避免短信验证码接口被刷。
前一段正好做一个项目的用户短信验证码登录功能,就研究...
现在不管什么项目,用到短信验证功能,都会在程序上设计一个短信验证码的获取次数限制,这样主要是避免短信验证码接口被刷。
前一段正好做一个项目的用户短信验证码登录功能,就研究了以下,下面贴出来分享一下。
这里涉及到的短信接口,用的第三方短信接口—动力思维思维乐信的(),如果想了解短信接口接入,可以到他们官网,查看下短信接口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; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。