博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
短信验证码实现(转)
阅读量:7145 次
发布时间:2019-06-29

本文共 1459 字,大约阅读时间需要 4 分钟。

  我们在使用移动、电信等运营商网上营业厅的时候,为确保业务的完整和正确性,经常会需要用到短信的验证码。最近因为某省业务需要,也做了个类似的功能。

原理很简单,就是在用户点击"获取验证码"的时候,Ajax获取一串固定位数的数字,然后写数据库发短信,写Cookie设置验证码的有效期。
JS请求验证码如下:

复制代码
$.ajax({
type: "GET",
url: "../Ajax/smsrandcodetest.ashx?phone=" + phone.val() + "&smsCodeRand=" + num,
success: function(result) {
if (result == "Y") {
alert("验证码已发送至您输入的手机号!有效期5分钟");
RemainTime();
}
else {
alert("验证码获取失败!请重新获取");
}
},
error: function() { alert("error"); }
});
//获取6位随机验证码
function random() {
var num = "";
for (i = 0; i < 6; i++) {
num = num + Math.floor(Math.random() * 10);
}
return num;
}
//验证码有效期倒计时
function RemainTime() {
var iSecond;
var sSecond = "", sTime = "";
if (iTime >= 0) {
iSecond = parseInt(iTime % 300);
if (iSecond >= 0) {
sSecond = iTime + "秒";
}
sTime = "<span style='color:darkorange;font-size:13px;'>" + sSecond + "</span>";
if (iTime == 0) {
clearTimeout(Account);
sTime = "<span style='color:red;font-size:12px;'>验证码已过期</span>";
}
else {
Account = setTimeout("RemainTime()", 1000);
}
iTime = iTime - 1;
}
$("#endtime").html(sTime);
}
复制代码

前端要处理的工作基本如上,现在要在HttpHandler中添加逻辑了,为了防止Js生成的验证码不符规则,我们在后端重新生成一次:

复制代码
if (smscoderand.Length != 6) //如果JS生成的随机码不符,则用C#生成随机码
{
smscoderand = GetRandom();
}
//写短信数据,发SMS
//写Cookie,设置验证码有效期,比如5分钟
//注:如果以上都处理成功,返回"Y",处理失败,返回"N"
复制代码

这里为了方便,验证码的有效期验证就用Cookie来完成。在业务提交的时候,会获取客户端的这个Cookie,看是否存在,如果不存在肯定就是过期了。如果后续业务扩展可能会考虑加上数据库的有效期验证,以及一些其它的规则,比如一小时、一天内限制发送验证码的条数(总不能让你无限制的发送短信吧) 等等。

http://www.cnblogs.com/maoniu602/archive/2011/12/26/2302472.html

 

你可能感兴趣的文章
HTML标签属性
查看>>
xmpp使用经验
查看>>
CGContextAddArc
查看>>
线段树
查看>>
二分查找的两种实现(循环与递归)
查看>>
C语言中volatile关键字的作用
查看>>
cp命令详解
查看>>
Android之AlarmManager
查看>>
陶哲轩实分析命题6.4.12
查看>>
陶哲轩实分析 习题 7.3.3
查看>>
小试下新博客,一个列传行的SQL
查看>>
使用dockerfile创建镜像
查看>>
带你一分钟理解闭包--js面向对象编程
查看>>
MySql基本使用方法
查看>>
[转]TCP 状态机
查看>>
mysql 原理 ~ innodb恢复机制
查看>>
水题 Codeforces Round #296 (Div. 2) A. Playing with Paper
查看>>
爬取我主良缘,获取个人图片及其信息
查看>>
字符型设备驱动程序-first-printf以及点亮LED灯(四)
查看>>
KAFKA 监控管理界面 KAFKA EAGLE 安装
查看>>