JavaScript实现页面动态验证码的实现示例
导读:收集整理的这篇文章主要介绍了JavaScript实现页面动态验证码的实现示例,觉得挺不错的,现在分享给大家,也给大家做个参考。 引言:现在很多在@R_412_2126@或注册的时候为了防...
收集整理的这篇文章主要介绍了JavaScript实现页面动态验证码的实现示例,觉得挺不错的,现在分享给大家,也给大家做个参考。 引言:
现在很多在@R_412_2126@或注册的时候为了防止程序攻击,加入了动态验证的技术,一般是让用户输入随即生成的验证码来实现。我自己写了一个没有跟后台交互的,就在前端验证,发出来给大家看看。
效果图:
实现思路:
- 把数字和字母放到一个数组中,通过随机的方式取得数组下标,总共取4个组成验证码;
- 把验证码渲染出来(一个一个的渲染);
- 绘制一定数量的干扰线,随机颜色;
- 输入验证码,输入4位以后去验证,正确显示钩,错误显示叉并且刷新验证码。
编写构造函数
文本构造函数
//文字的构造函数 function Text(o){ this.x=0,//x坐标 this.y=0,//y坐标 this.text='',//内容 this.font=null; //字体 this.textAlign=null; //对齐方式 this.inIT(o); } Text.PRototyPE.init=function(o){ for(VAR key in o){ this[key]=o[key]; } } Text.prototype.render=function(context){ this.ctx=context; innerRender(this); function innerRender(obj){ var ctx=obj.ctx; ctx.save() ctx.beginPath(); ctx.translate(obj.x,obj.y); if(obj.font){ ctx.font=obj.font; } if(obj.textAlign){ ctx.textAlign=obj.textAlign; } if(obj.fill){ //是否填充 obj.fillStyle?(ctx.fillStyle=obj.fillStyle):null; ctx.fillText(obj.text,0,0); } ctx.reStore(); } return this; }
线段构造函数
//直线的构造 function Line(ctx,o){ this.x=0,//x坐标 this.y=0,//y坐标 this.startX=0,//开始点x位置 this.startY=0, //开始点y位置 this.endX=0,//结束点x位置 this.endY=0; //结束点y位置 this.thin=false; //设置变细系数 this.ctx=ctx; this.init(o); } Line.prototype.init=function(o){ for(var key in o){ this[key]=o[key]; } } Line.prototype.render=function(){ innerRender(this); function innerRender(obj){ var ctx=obj.ctx; ctx.save() ctx.beginPath(); ctx.translate(obj.x,obj.y); if(obj.thin){ ctx.translate(0.5,0.5); } if(obj.lineWidth){ //设定线宽 ctx.lineWidth=obj.lineWidth; } if(obj.strokeStyle){ ctx.strokeStyle=obj.strokeStyle; } //划线 ctx.moveTo(obj.startX, obj.startY); ctx.lineto(obj.endX, obj.endY); ctx.stroke(); ctx.restore(); } return this; }
按长度获取验证码
//根据指定长度生成随机字母数字 Verifiable.prototype.randomWord=function(range){ var str = "",pos, arr = ['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', '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; irange; i++){ pos = Math.round(Math.random() * (arr.length-1)); str += arr[pos]; } return str; }
绘制文字
//绘制文字 Verifiable.prototype.drawText=function(){ var that=this; var count = 4; //文字个数 var textW = 40; //文字所占宽 var code=this.code = this.randomWord(count); var codeArr = code.split(""); var text,x ; codeArr.foreach(function(c,i){ x = that.w/count*i+textW/2; //绘制文字 text = new Text({ x:x, y:textW-10, text:c, font:'30px ans-serif', textAlign:'center', fill:true, fillStyle:'#412D6A' } ); that.renderArr.push(text); } ) }
此时效果:
绘制干扰线
//绘制干扰线 Verifiable.prototype.interfering=function(){ var count = this.lineCount=20,line,ctx=this.ctx; var startX, startY, endX, endY, color; for(var i=0; icount; i++){ //随机开始坐标,结束坐标、颜色 startX = _.getRandom(0,140); startY = _.getRandom(0,40); endX = _.getRandom(0,140); endY = _.getRandom(0,40); color = _.getRandomColor(); //定义一条直线 line = new Line(ctx,{ x:0, y:0, startX:startX, startY:startY, endX:endX, endY:endY, strokeStyle:color } ) this.renderArr.push(line); } }
此时效果如下:
加入页面布局
!DOCTYPE htML> html lang="zh"> head> meta charset="UTF-8"> title> verifiable/title> style> #box{ width:140px; height:40px; position:absolute; } #inputDiv{ width:220px; position:absolute; margin:0 auto; left:0; top:30px; right:0; bottom:0; } #container{ width:220px; height:60px; position:absolute; margin:0 auto; left:0; top:60px; right:0; bottom:0; } .refresh{ position:absolute; left:140px; } /style> /head> body> div id='inputDiv'> 验证码:input size=10 id='codeInput'> img id='stateImg' style="vertical-align: middle; width:20px"> /img> /div> div id="container"> div id='box'> /div> a href="javascript:void 0" class="refresh" onclick="refresh()"> 换一张/a> /div> /body> script type="text/javascript" src='verifiable.js'> /script> script type="text/javascript"> var box = document.getElementById('box'); var stateImg = document.getElementById('stateImg'); var codeInput = document.getElementById('codeInput'); verifiable.init(box,codeInput,stateImg); //换一张 function refresh(){ verifiable.renderArr.length=0; verifiable.draw(); } /script> /html>
加入输入框事件
//输入框事件 Verifiable.prototype.inputValid=function(input){ var val = input.value; if(val.length4) return ; if(this.code==val){ console.LOG('suc'); this.result(0); } else{ this.result(1); } }
加入成功、失败验证
//处理结果 Verifiable.prototype.result=function(result){ var codeInput = this.codeInput; var stateImg = this.stateImg; if(result==0){ //成功 stateImg.src="./images/suc.jpeg"; codeInput.readOnly=true; } else { //失败 codeInput.readOnly=false; stateImg.src="./images/fail.jpeg"; this.renderArr.length=0; this.draw(); } }
完成
代码下载
到此这篇关于JavaScript实现页面动态验证码的实现示例的文章就介绍到这了,更多相关JavaScript 动态验证码内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:- Jsp生成页面验证码的方法[附代码]
- js实现简单的验证码
- js实现点击获取验证码倒计时效果
- JS 验证码功能的三种实现方式
- JS制作图形验证码实现代码
- js+canvas实现滑动拼图验证码功能
- js+html制作简单验证码
- JS验证码实现代码
- js插件实现图片滑动验证码
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: JavaScript实现页面动态验证码的实现示例
本文地址: https://pptw.com/jishu/594949.html