怎样用js实现生成验证码并校验的功能?
Admin 2021-08-27 群英技术资讯 1582 次浏览
这篇文章给大家分享的是怎样用js实现生成验证码并校验的内容。小编觉得挺实用的,在很多注册登录页面都能使用到,因此分享给大家做个参考,感兴趣的朋友就继续往下看吧。
JavaScript之随机码的生成与校验,供大家参考,具体内容如下
由于获取事件源有两种写法,所以在此处都附上:
这个是直接用var去定义的
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>随机验证码校验</title>
<style type="text/css">
#code{
width: 100px;
height: 100px;
background-color: #ddd;
padding: 10px;
line-height: 100px;
text-align: center;
font-size: 20px;
color: red;
/*font-weight: bold;*/
}
</style>
</head>
<body>
<div id="code"></div>
<input type="text" name="" id="newCode">
<input type="button" name="" id="validate" value="验证">
<script type="text/javascript">
window.onload = function (){
var code;
// 1.获取对应的标签
var codeDiv = document.getElementById("code");
var newCodeInput = document.getElementById("newCode");
var validate = document.getElementById("validate");
// 加载页面获取对应验证码
creatCode()
// 1.获取min到max之间的整数 1~100
function random(max,min){
return Math.floor(Math.random()*(max-min)+min);
}
function creatCode(){
code = "";
// 设置长度
var codeLenth = 4;
var randomCode =[0,1,2,3,4,5,6,7,8,9,"A","B","C","D","E","F","G","H","I","J","K","L","M","N", "O","P","Q","R","S","T","U","V","W","X","Y","Z"];
for(var i=0;i<codeLenth;i++){
// 设置随机范围36范围
var index = random(0,36);
code += randomCode[index];
}
codeDiv.innerHTML = code;
}
// 验证按钮校验
validate.onclick = function (){
// 获取输入用户的验证码
var newCode = newCodeInput.value.toUpperCase();
if (newCode === code){
// 验证成功 跳转对应的网址
window.location.href = "http://www.baidu.com";
}else {
// 验证失败
alert("验证失败,请重新输入")
// 输入框置空
newCodeInput.value = "";
// 重新获取验证码
creatCode();
}
}
}
</script>
</body>
</html>
这个是用function定义变量的:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>随机验证码校验</title>
<style type="text/css">
#code{
width: 100px;
height: 100px;
background-color: #ddd;
padding: 10px;
line-height: 100px;
text-align: center;
font-size: 20px;
color: red;
/*font-weight: bold;*/
}
</style>
</head>
<body>
<div id="code"></div>
<input type="text" name="" id="newCode">
<input type="button" name="" id="validate" value="验证">
<script type="text/javascript">
window.onload = function (){
var code;
// 1.获取对应的标签(获取事件源)
function $(id){
return typeof id === "string"?document.getElementById(id):null;
}
// 加载页面获取对应验证码
creatCode()
// 1.获取min到max之间的整数 1~100
function random(max,min){
return Math.floor(Math.random()*(max-min)+min);
}
function creatCode(){
code = "";
// 设置长度
var codeLenth = 4;
var randomCode =[0,1,2,3,4,5,6,7,8,9,"A","B","C","D","E","F","G","H","I","J","K","L","M","N","O", "P","Q","R","S","T","U","V","W","X","Y","Z"];
for(var i=0;i<codeLenth;i++){
// 设置随机范围36范围
var index = random(0,36);
code += randomCode[index];
}
$("code").innerHTML = code;
}
// 验证按钮校验
$("validate").onclick = function (){
// 获取输入用户的验证码
var newCode = $("newCode").value.toUpperCase();
if (newCode === code){
// 验证成功 跳转对应的网址
window.location.href = "http://www.baidu.com";
}else {
// 验证失败
alert("验证失败,请重新输入")
// 输入框置空
$("newCode").value = "";
// 重新获取验证码
creatCode();
}
}
}
</script>
</body>
</html>
两种方式所实现效果一样。附上效果图:

当输入错误的数据进行验证时,会提示:

当输入正确的数据进行验证时,点击验证,如果验证成功,会跳转指定路径。
以上就是关于js实现生成验证码并校验功能的代码,有需要的朋友可以参考学习,希望能对大家学习JavaScript有帮助,想要了解更多js生成验证码的相关内容,大家可以关注其他文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
并发控制是确保及时纠正由并发操作导致的错误的一种机制。我们在开发过程中,有时会遇到需要控制任务并发执行数量的需求。那么就需要做并发控制。例如一个爬虫程序,可以通过限制其并发任务数量来降低请求频率,从而避免由于请求过于频繁被封禁问题的发生。关于并发控制大家都了解了,下面我们就来说说JavaScript怎样实现并发控制?
微信小程序实现上传视频功能 本文实例为大家分享了微信小程序上传视频,供大家参考,具体内容如下 微信开发者工具需要安装ffmpeg环境才能正常使用下面的官方方法. 1.调用官方提供的方法(wx.chooseMedia) choosevideo(){ let that=this console.log("上传视频的方法") wx.chooseMedia({ count: 1, //上传视频的个数 mediaType:['video'], //限制上传的类型 ...
方法:1、利用index()和parent()方法来获取当前元素的行位置,语法为“元素对象.parent().index()+1;”;2、利用index()方法来获取当前元素的列位置,语法为“元素对象.index()+1;”。
这篇文章主要介绍如何用JS写一个发布订阅模式,什么是发布订阅模式?能手写实现一下吗?它和观察者模式有区别吗?带着疑惑一起解开下面文章的内容吧
JavaScript之日期特效的具体代码,供大家参考,具体内容如下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008