日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript實現頁面動態驗證碼的實現示例

瀏覽:230日期:2023-10-03 13:37:38
引言:

現在很多在用戶登陸或注冊的時候為了防止程序攻擊,加入了動態驗證的技術,一般是讓用戶輸入隨即生成的驗證碼來實現。我自己寫了一個沒有跟后臺交互的,就在前端驗證,發出來給大家看看。

效果圖:

JavaScript實現頁面動態驗證碼的實現示例

實現思路: 把數字和字母放到一個數組中,通過隨機的方式取得數組下標,總共取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; i<range; 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);})}

此時效果:

JavaScript實現頁面動態驗證碼的實現示例

繪制干擾線

//繪制干擾線Verifiable.prototype.interfering=function(){var count = this.lineCount=20,line,ctx=this.ctx;var startX,startY,endX,endY,color;for(var i=0;i<count;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);}}

此時效果如下:

JavaScript實現頁面動態驗證碼的實現示例

加入頁面布局

<!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' 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.length<4) 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='http://m.b3g6.com/bcjs/images/suc.jpeg';codeInput.readOnly=true;}else {//失敗codeInput.readOnly=false;stateImg.src='http://m.b3g6.com/bcjs/images/fail.jpeg';this.renderArr.length=0;this.draw();}}

完成

JavaScript實現頁面動態驗證碼的實現示例

代碼下載

到此這篇關于JavaScript實現頁面動態驗證碼的實現示例的文章就介紹到這了,更多相關JavaScript 動態驗證碼內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
中文字幕一区二区精品区| 性一交一乱一区二区洋洋av| 亚洲一区免费| 精品1区2区3区4区| 日韩一区二区免费看| 在线综合亚洲| 亚洲一区二区日韩| 日本在线一区二区三区| 亚洲麻豆一区| **爰片久久毛片| 精品伊人久久久| 91亚洲人成网污www| 亚洲精品在线影院| 一级欧洲+日本+国产| 蜜桃久久久久久| 国产精品v日韩精品v欧美精品网站| 日韩中文字幕无砖| 麻豆成人在线观看| 亚洲综合电影| 午夜欧美在线| 欧美日韩91| 加勒比视频一区| 午夜久久黄色| 国产精品任我爽爆在线播放 | 国产乱人伦精品一区| 国产精品蜜芽在线观看| 韩国三级一区| 噜噜噜躁狠狠躁狠狠精品视频| 日韩毛片一区| 亚洲精品福利电影| 日韩手机在线| 99久久九九| 日本不卡一二三区黄网| 精品精品国产三级a∨在线| 亚洲精品97| 麻豆中文一区二区| 波多野结衣久久精品| 亚久久调教视频| 国产欧美日本| 久草精品视频| 国产香蕉精品| аⅴ资源天堂资源库在线| 亚洲免费婷婷| 丝袜亚洲另类欧美| 欧美成人久久| 日韩不卡在线| 欧美成a人免费观看久久| 精品国产中文字幕第一页| 日韩视频一区| 国产精品久久久久久久久久久久久久久 | 亚洲国产综合在线看不卡| 精品一区二区三区免费看| 亚洲乱亚洲高清| 99久久激情| 黄色aa久久| 99久久九九| 鲁大师精品99久久久| 欧美一区91| 丝袜美腿亚洲色图| 一区在线免费观看| 国产一区不卡| 久久久一本精品| 亚洲欧美日韩视频二区| 亚洲精品黄色| 日本欧美在线| 日韩精品久久理论片| 欧美私人啪啪vps| 日本va欧美va精品发布| 免费观看亚洲天堂| 精品国产一级| 另类综合日韩欧美亚洲| 国产一区调教| 午夜电影亚洲| 国产毛片久久久| 都市激情国产精品| 欧美亚洲二区| 亚洲最新av| 香蕉成人av| 国产亚洲欧美日韩精品一区二区三区| 日韩和的一区二在线| 日本精品在线播放| 美女视频黄久久| 99精品美女| 亚洲丝袜啪啪| 国产一区二区视频在线看| 日韩一区二区免费看| 久久成人高清| 午夜久久影院| 久久中文字幕一区二区三区| 欧美一区二区三区高清视频| 91麻豆精品激情在线观看最新| 黄色欧美在线| 免播放器亚洲一区| 9999国产精品| 亚洲图片久久| 欧美成人a交片免费看| 亚洲精品动态| 人人精品亚洲| 国产第一亚洲| 中文一区一区三区高中清不卡免费| 久久电影一区| 亚洲深夜视频| 精品久久久中文字幕| 日韩二区在线观看| 中文欧美日韩| 日韩黄色大片网站| 91精品日本| 在线精品一区| 婷婷色综合网| 久久婷婷一区| 精品久久美女| 久久的色偷偷| 一级欧美视频| 黄页网站一区| 99免费精品| 欧美少妇精品| 欧美韩日一区| 免费一二一二在线视频| 日韩精品看片| 欧美日韩国产一区精品一区| 欧美日韩国产在线一区| 尤物精品在线| 日韩一区二区久久| 亚洲专区欧美专区| 日韩欧美2区| 在线一区电影| 日本成人精品| 国产一区二区三区不卡av| 亚洲三级av| 日韩专区欧美专区| 亚洲二区在线| 日韩中文影院| 色婷婷久久久| 日韩中文在线电影| 岛国av免费在线观看| 久久免费福利| 国产成人免费视频网站视频社区| 国产精品天堂蜜av在线播放| 国产麻豆一区| 国产极品模特精品一二| 国产精品一区高清| 国产精品一区二区三区www| 蜜桃久久久久久| 亚州欧美在线| 日韩高清在线一区| 国产精品大片| 97人人精品| 欧美专区18| 久久精品xxxxx| 欧美日韩国产观看视频| 在线视频亚洲| 国产精品porn| 中文在线免费视频| 香蕉久久国产| 国产精品久久久久久久久免费高清 | 精品国产一区二区三区2021| 国产成人精品一区二区三区在线| 国产精品成久久久久| 午夜日韩在线| 国产精品美女午夜爽爽| 成人精品亚洲| 日本一区免费网站| 国产精品13p| 午夜久久黄色| 国产高清亚洲| 欧美日韩国产传媒| 国产精品亚洲综合在线观看| 视频小说一区二区| 久久国产免费看| 欧美日韩少妇| 国产精品美女久久久| 欧美成人亚洲| 欧美视频二区| 欧美日韩国产高清电影| 久久国产人妖系列| 亚洲成人一区| 国产精品xxx在线观看| 免费日韩一区二区| 久久a爱视频| 2023国产精品久久久精品双| 久久av导航| 日本亚洲不卡| 99久久精品费精品国产| 国产亚洲精aa在线看| 免费在线观看精品| 欧美精品一区二区久久| 色一区二区三区| 国产精品超碰| 日本午夜精品一区二区三区电影| 国产字幕视频一区二区| 国产一区二区三区不卡视频网站| 亚洲一区二区三区四区电影| 电影亚洲精品噜噜在线观看| 在线综合亚洲| 精品中文字幕一区二区三区四区| 亚洲香蕉久久| 亚洲一区导航| 久久成人亚洲| 久久福利影视| 性色一区二区|