java短信驗證碼獲取次數(shù)限制實例
現(xiàn)在不管什么項目,用到短信驗證功能,都會在程序上設(shè)計一個短信驗證碼的獲取次數(shù)限制,這樣主要是避免短信驗證碼接口被刷。
前一段正好做一個項目的用戶短信驗證碼登錄功能,就研究了以下,下面貼出來分享一下。
這里涉及到的短信接口,用的第三方短信接口—動力思維思維樂信的(http://www.lx598.com/),如果想了解短信接口接入,可以到他們官網(wǎng),查看下短信接口API文檔說明,參考下面的代碼應(yīng)該就能弄明白。
用戶注冊部分,主要代碼如下:
//主要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));//設(shè)置使用狀態(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); // 設(shè)置驗證碼失效時間為24小時
account.setFREGISTERSOURCE(fromSource);//設(shè)置注冊來源
// 判斷該手機是否獲取過驗證碼
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());//設(shè)置驗證碼有效時間
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 當(dāng)前時間 格式:YYYYMMDD HHMISS 例如:20130806102030
* @param aimcodes 手機號多個手機號之間英文半角逗號隔開
* @param content 內(nèi)容后加簽名
* @param schTime 定時時間格式如:2010-01-01 08:00:00
* @return 服務(wù)端返回的結(jié)果 ok:業(yè)務(wù)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")); //空格標(biāo)點符號做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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺析Java如何優(yōu)雅的設(shè)計接口狀態(tài)碼和異常
HTTP協(xié)議里定義了一系列的狀態(tài)碼用來表明請求的狀態(tài),如常用的200表示請求正常,404表示請求的資源不存在,所以本文就來和大家討論一下如何優(yōu)雅的設(shè)計接口狀態(tài)碼和異常,感興趣的可以了解下2024-03-03
基于Java回顧之網(wǎng)絡(luò)通信的應(yīng)用分析
在這篇文章里,我們主要討論如何使用Java實現(xiàn)網(wǎng)絡(luò)通信,包括TCP通信、UDP通信、多播以及NIO2013-05-05
通過Java實現(xiàn)設(shè)置Word文檔頁邊距的方法詳解
頁邊距是指頁面的邊線到文字的距離。通??稍陧撨吘鄡?nèi)部的可打印區(qū)域中插入文字和圖形等。今天這篇文章將為您展示如何通過編程方式,設(shè)置Word?文檔頁邊距,感興趣的可以了解一下2023-02-02
用Java實現(xiàn)小球碰壁反彈的簡單實例(算法十分簡單)
下面小編就為大家?guī)硪黄肑ava實現(xiàn)小球碰壁反彈的簡單實例(算法十分簡單)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
Tk.mybatis零sql語句實現(xiàn)動態(tài)sql查詢的方法(4種)

