html<!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no"> <title>jQuery web verification code plug-in</title> <link rel="stylesheet" type="text/css" href="css/verify.css" rel="external nofollow" > </head> <body> <h3>Digital verification code</h3> <div id="mpanel2" ></div> <button type="button" id="check-btn" class="verify-btn">Confirm</button> <h3 style="margin-top: 20px">Arithmetic verification code</h3> <div id="mpanel3"></div> <button type="button" id="check-btn2" class="verify-btn">Confirm</button> <h3 style="margin-top: 20px">Slide verification code</h3> <div id="mpanel1" ></div> <h3 style="margin-top: 20px">Puzzle verification code</h3> <div id="mpanel4"></div> <h3 style="margin-top:30px;">Click the verification code</h3> <div id="mpanel5"> </div> <div id="mpanel6" style="margin-top:30px;"> </div> <script type="text/javascript" src="js/jquery.min.js"></script> <script type="text/javascript" src="js/verify.js" ></script> <script type="text/javascript"> $('#mpanel2').codeVerify({ type : 1, width : '200px', height : '50px', fontSize : '30px', codeLength : 6, btnId : 'check-btn', ready : function() { }, success : function() { alert('Verify match!'); }, error : function() { alert('Verification code does not match!'); } }); $('#mpanel3').codeVerify({ type : 2, figure : 50, //Number of digits, only valid when type=2 arith : 0, //Algorithm, supports addition, subtraction, and multiplication. If left blank, it is random, only valid when type=2 width : '200px', height : '50px', fontSize : '30px', btnId : 'check-btn2', ready : function() { }, success : function() { alert('Verify match!'); }, error : function() { alert('Verification code does not match!'); } }); $('#mpanel1').slideVerify({ type : 1, //Type vOffset : 5, //Error amount, adjust according to needs barSize : { width : '50%', height : '40px', }, ready : function() { }, success : function() { alert('Verification successful, add your own code!'); //......subsequent operations }, error : function() { // alert('Verification failed!'); } }); $('#mpanel4').slideVerify({ type : 2, //type vOffset : 5, //error, adjust according to needs vSpace : 5, //interval imgName : ['1.jpg', '2.jpg'], imgSize : { width: '300px', height: '200px', }, blockSize : { width: '40px', height: '40px', }, barSize : { width : '300px', height : '40px', }, ready : function() { }, success : function() { alert('Verification successful, add your own code!'); //......subsequent operations }, error : function() { // alert('Verification failed!'); } }); $('#mpanel5').pointsVerify({ defaultNum : 4, //Default number of characters checkNum : 2, //Verification number of characters vSpace : 5, //Interval imgName : ['1.jpg', '2.jpg'], imgSize : { width: '400px', height: '200px', }, barSize : { width : '400px', height : '40px', }, ready : function() { }, success : function() { alert('Verification successful, add your own code!'); //......subsequent operations }, error : function() { // alert('Verification failed!'); } }); $('#mpanel6').pointsVerify({ defaultNum : 4, //Default number of characters checkNum : 2, //Verification number of characters vSpace : 5, //Interval imgName : ['1.jpg', '2.jpg'], imgSize : { width: '400px', height: '200px', }, barSize : { width : '400px', height : '40px', }, ready : function() { }, success : function() { alert('Verification successful, add your own code!'); //......subsequent operations }, error : function() { // alert('Verification failed!'); } }); </script> </body> </html> verify.css/*Regular verification code*/ .verify-code { font-size: 20px; text-align: center; cursor: pointer; margin-bottom: 5px; border: 1px solid #ddd; } .cerify-code-panel { height:100%; overflow:hidden; } .verify-code-area { float:left; } .verify-input-area { float: left; width: 60%; padding-right: 10px; } .verify-change-area { line-height: 30px; float: left; } .varify-input-code { display:inline-block; width: 100%; height: 25px; } .verify-change-code { color: #337AB7; cursor: pointer; } .verify-btn { width: 200px; height: 30px; background-color: #337AB7; color:#FFFFFF; border:none; margin-top: 10px; } /*Slide verification code*/ .verify-bar-area { position: relative; background: #FFFFFF; text-align: center; -webkit-box-sizing: content-box; -moz-box-sizing: content-box; box-sizing: content-box; border: 1px solid #ddd; -webkit-border-radius: 4px; } .verify-bar-area .verify-move-block { position: absolute; top: 0px; left: 0; background: #fff; cursor: pointer; -webkit-box-sizing: content-box; -moz-box-sizing: content-box; box-sizing: content-box; box-shadow: 0 0 2px #888888; -webkit-border-radius: 1px; } .verify-bar-area .verify-move-block:hover { background-color: #337ab7; color: #FFFFFF; } .verify-bar-area .verify-left-bar { position: absolute; top: -1px; left: -1px; background: #f0fff0; cursor: pointer; -webkit-box-sizing: content-box; -moz-box-sizing: content-box; box-sizing: content-box; border: 1px solid #ddd; } .verify-img-panel { margin:0; -webkit-box-sizing: content-box; -moz-box-sizing: content-box; box-sizing: content-box; border: 1px solid #ddd; border-radius: 3px; position: relative; } .verify-img-panel .verify-refresh { width: 25px; height: 25px; text-align:center; padding: 5px; cursor: pointer; position: absolute; top: 0; right: 0; z-index: 2; } .verify-img-panel .icon-refresh { font-size: 20px; color: #fff; } .verify-img-panel .verify-gap { background-color: #fff; position: relative; z-index: 2; border:1px solid #fff; } .verify-bar-area .verify-move-block .verify-sub-block { position: absolute; text-align: center; z-index: 3; border: 1px solid #fff; } .verify-bar-area .verify-move-block .verify-icon { font-size: 18px; } .verify-bar-area .verify-msg { z-index : 3; } /*font icon css*/ @font-face {font-family: "iconfont"; src: url('../fonts/iconfont.eot?t=1508229193188'); /* IE9*/ src: url('../fonts/iconfont.eot?t=1508229193188#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('data:application/x-font-woff;charset=utf-8;base64,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') format('woff'), url('../fonts/iconfont.ttf?t=1508229193188') format('truetype'), /* chrome, firefox, opera, Safari, Android, iOS 4.2+*/ url('../fonts/iconfont.svg?t=1508229193188#iconfont') format('svg'); /* iOS 4.1- */ } .iconfont { font-family:"iconfont" !important; font-size:16px; font-style:normal; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } .icon-check:before { content: "\e645"; } .icon-close:before { content: "\e646"; } .icon-right:before { content: "\e6a3"; } .icon-refresh:before { content: "\e6a4"; } verify.js/*! Verify-v0.1.0 MIT License by Big Bear*/ ;(function($, window, document, undefined) { //Define the constructor of Code var Code = function(ele, opt) { this.$element = ele, this.defaults = { type : 1, figure : 100, //Number of digits, only valid when type=2 arith : 0, //Algorithm, supports addition, subtraction, and multiplication. 0 is random, only valid when type=2 width : '200px', height : '60px', fontSize : '30px', codeLength : 6, btnId : 'check-btn', ready : function(){}, success : function(){}, error : function(){} }, this.options = $.extend({}, this.defaults, opt) }; var _code_chars = [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']; var _code_color1 = ['#fffff0', '#f0ffff', '#f0fff0', '#fff0f0']; var _code_color2 = ['#FF0033', '#006699', '#993366', '#FF9900', '#66CC66', '#FF33CC']; //Define the Code method Code.prototype = { init : function() { var _this = this; this.loadDom(); this.setCode(); this.options.ready(); this.$element[0].onselectstart = document.body.ondrag = function(){ return false; }; //Click verification code this.$element.find('.verify-code, .verify-change-code').on('click', function() { _this.setCode(); }); //Confirm the click event this.htmlDoms.code_btn.on('click', function() { _this.checkCode(); }); }, //Load the page loadDom : function() { var panelHtml = '<div class="cerify-code-panel">\ <div class="verify-code"></div>\ <div class="verify-code-area">\ <div class="verify-input-area">\ <input type="text" class="varify-input-code"/>\ </div>\ <div class="verify-change-area">\ <a class="verify-change-code">Change one</a>\ </div>\ </div>\ </div>'; this.$element.append(panelHtml); this.htmlDoms = { code_btn : $('#'+this.options.btnId), code : this.$element.find('.verify-code'), code_area : this.$element.find('.verify-code-area'), code_input : this.$element.find('.varify-input-code'), }; this.htmlDoms.code.css({'width':this.options.width, 'height':this.options.height,'line-height':this.options.height, 'font-size':this.options.fontSize}); this.htmlDoms.code_area.css({'width':this.options.width}); }, //Set verification code setCode : function() { var color1Num = Math.floor(Math.random() * 3); var color2Num = Math.floor(Math.random() * 5); this.htmlDoms.code.css({'background-color': _code_color1[color1Num], 'color': _code_color2[color2Num]}); this.htmlDoms.code_input.val(''); var code = ''; this.code_chose = ''; if(this.options.type == 1) { //Ordinary verification code for(var i = 0; i < this.options.codeLength; i++) { var charNum = Math.floor(Math.random() * 52); var tmpStyle = (charNum%2 ==0)? "font-style:italic;margin-right: 10px;":"font-weight:bolder;"; tmpStyle += (Math.floor(Math.random() * 2) == 1)? "font-weight: bolder;":""; this.code_chose += _code_chars[charNum]; code += '<font style="'+tmpStyle+'">'+_code_chars[charNum]+'</font>'; } }else { //Algorithm verification code var num1 = Math.floor(Math.random() * this.options.figure); var num2 = Math.floor(Math.random() * this.options.figure); if(this.options.arith == 0) { var tmparith = Math.floor(Math.random() * 3); } switch(tmparith) { case 1: this.code_chose = parseInt(num1) + parseInt(num2); code = num1 + ' + ' + num2 + ' = ?'; break; case 2: if(parseInt(num1) < parseInt(num2)) { var tmpnum = num1; num1 = num2; num2 = tmpnum; } this.code_chose = parseInt(num1) - parseInt(num2); code = num1 + ' - ' + num2 + ' = ?'; break; default : this.code_chose = parseInt(num1) * parseInt(num2); code = num1 + ' × ' + num2 + ' = ?'; break; } } this.htmlDoms.code.html(code); }, //Compare verification code checkCode : function() { if(this.options.type == 1) { //Ordinary verification code var own_input = this.htmlDoms.code_input.val().toUpperCase(); this.code_chose = this.code_chose.toUpperCase(); }else { var own_input = this.htmlDoms.code_input.val(); } if(own_input == this.code_chose) { this.options.success(); }else { this.options.error(); this.setCode(); } } }; //Define Slide's constructor var Slide = function(ele, opt) { this.$element = ele, this.defaults = { type : 1, vOffset: 5, vSpace : 5, imgName : ['1.jpg', '2.jpg'], imgSize : { width: '400px', height: '200px', }, blockSize : { width: '50px', height: '50px', }, barSize : { width : '400px', height : '40px', }, ready : function(){}, success : function(){}, error : function(){} }, this.options = $.extend({}, this.defaults, opt) }; //Define Slide's method Slide.prototype = { init: function() { var _this = this; //Load the page this.loadDom(); this.options.ready(); this.$element[0].onselectstart = document.body.ondrag = function(){ return false; }; //Press this.htmlDoms.move_block.on('touchstart', function(e) { _this.start(e); }); this.htmlDoms.move_block.on('mousedown', function(e) { _this.start(e); }); //Dragwindow.addEventListener("touchmove", function(e) { _this.move(e); }); window.addEventListener("mousemove", function(e) { _this.move(e); }); //Mouse release window.addEventListener("touchend", function() { _this.end(); }); window.addEventListener("mouseup", function() { _this.end(); }); //Refresh_this.$element.find('.verify-refresh').on('click', function() { _this.refresh(); }); }, // Initialize loading loadDom : function() { this.img_rand = Math.floor(Math.random() * this.options.imgName.length); //Random background image var panelHtml = ''; var tmpHtml = ''; if(this.options.type != 1) { //Picture sliding panelHtml += '<div class="verify-img-panel">\ <div class="verify-refresh">\ <i class="iconfont icon-refresh"></i>\ </div>\ <div class="verify-gap"></div>\ </div>'; tmpHtml = '<div class="verify-sub-block"></div>'; } panelHtml += '<div class="verify-bar-area">\ <span class="verify-msg">Swipe right to complete verification</span>\ <div class="verify-left-bar">\ <span class="verify-msg"></span>\ <div class="verify-move-block">\ <i class="verify-icon iconfont icon-right"></i>'+tmpHtml+'</div></div></div>'; this.$element.append(panelHtml); this.htmlDoms = { gap : this.$element.find('.verify-gap'), sub_block : this.$element.find('.verify-sub-block'), img_panel : this.$element.find('.verify-img-panel'), bar_area : this.$element.find('.verify-bar-area'), move_block : this.$element.find('.verify-move-block'), left_bar : this.$element.find('.verify-left-bar'), msg : this.$element.find('.verify-msg'), icon : this.$element.find('.verify-icon'), refresh : this.$element.find('.verify-refresh') }; this.status = false; //Mouse status this.setSize = this.resetSize(this); //Reset width and height this.htmlDoms.gap.css({'width': this.options.blockSize.width, 'height': this.options.blockSize.height}); this.htmlDoms.sub_block.css({'width': this.options.blockSize.width, 'height': this.options.blockSize.height}); this.htmlDoms.img_panel.css({'width': this.setSize.img_width, 'height': this.setSize.img_height, 'background': 'url(images/'+this.options.imgName[this.img_rand]+')', 'background-size' : this.setSize.img_width + ' '+ this.setSize.img_height}); this.htmlDoms.bar_area.css({'width': this.setSize.bar_width, 'height': this.options.barSize.height, 'line-height':this.options.barSize.height}); this.htmlDoms.move_block.css({'width': this.options.barSize.height, 'height': this.options.barSize.height}); this.htmlDoms.left_bar.css({'width': this.options.barSize.height, 'height': this.options.barSize.height}); this.randSet(); }, //Mouse press start: function(e) { this.htmlDoms.msg.text(''); this.htmlDoms.move_block.css('background-color', '#337ab7'); this.htmlDoms.left_bar.css('border-color', '#337AB7'); this.htmlDoms.icon.css('color', '#fff'); e.stopPropagation(); this.status = true; }, //Mouse movement move: function(e) { if(this.status) { if(!e.touches) { // compatible with mobile terminals var x = e.clientX; }else { //Compatible with PC var x = e.touches[0].pageX; } var bar_area_left = Slide.prototype.getLeft(this.htmlDoms.bar_area[0]); var move_block_left = x - bar_area_left; //The left value of the small square relative to the parent element if(this.options.type != 1) { //Picture sliding if(move_block_left >= this.htmlDoms.bar_area[0].offsetWidth - parseInt(parseInt(this.options.blockSize.width)/2) - 2) { move_block_left = this.htmlDoms.bar_area[0].offsetWidth - parseInt(parseInt(this.options.blockSize.width)/2) - 2; } }else { //Normal sliding if(move_block_left >= this.htmlDoms.bar_area[0].offsetWidth - parseInt(parseInt(this.options.barSize.height)/2) + 3) { this.$element.find('.verify-msg:eq(1)').text('Release verification'); move_block_left = this.htmlDoms.bar_area[0].offsetWidth - parseInt(parseInt(this.options.barSize.height)/2) + 3; }else { this.$element.find('.verify-msg:eq(1)').text(''); } } if(move_block_left <= 0) { move_block_left = parseInt(parseInt(this.options.blockSize.width)/2); } //The left value of the small square after dragging this.htmlDoms.move_block.css('left', move_block_left-parseInt(parseInt(this.options.blockSize.width)/2) + "px"); this.htmlDoms.left_bar.css('width', move_block_left-parseInt(parseInt(this.options.blockSize.width)/2) + "px"); } }, //Mouse release end: function() { var _this = this; //Judge whether it overlaps if(this.status) { if(this.options.type != 1) { //Picture sliding var vOffset = parseInt(this.options.vOffset); if(parseInt(this.htmlDoms.gap.css('left')) >= (parseInt(this.htmlDoms.move_block.css('left')) - vOffset) && parseInt(this.htmlDoms.gap.css('left')) <= (parseInt(this.htmlDoms.move_block.css('left')) + vOffset)) { this.htmlDoms.move_block.css('background-color', '#5cb85c'); this.htmlDoms.left_bar.css({'border-color': '#5cb85c', 'background-color': '#fff'}); this.htmlDoms.icon.css('color', '#fff'); this.htmlDoms.icon.removeClass('icon-right'); this.htmlDoms.icon.addClass('icon-check'); this.htmlDoms.refresh.hide(); this.htmlDoms.move_block.unbind('mousedown touchstart'); this.options.success(); }else{ this.htmlDoms.move_block.css('background-color', '#d9534f'); this.htmlDoms.left_bar.css('border-color', '#d9534f'); this.htmlDoms.icon.css('color', '#fff'); this.htmlDoms.icon.removeClass('icon-right'); this.htmlDoms.icon.addClass('icon-close'); setTimeout(function () { _this.htmlDoms.move_block.animate({'left':'0px'}, 'fast'); _this.htmlDoms.left_bar.animate({'width': '40px'}, 'fast'); _this.htmlDoms.left_bar.css({'border-color': '#ddd'}); _this.htmlDoms.move_block.css('background-color', '#fff'); _this.htmlDoms.icon.css('color', '#000'); _this.htmlDoms.icon.removeClass('icon-close'); _this.htmlDoms.icon.addClass('icon-right'); _this.$element.find('.verify-msg:eq(0)').text('Swipe right to complete verification'); }, 400); this.options.error(); } }else { //Normal sliding if(parseInt(this.htmlDoms.move_block.css('left')) >= (parseInt(this.setSize.bar_width) - parseInt(this.options.barSize.height) - parseInt(this.options.vOffset))) { this.htmlDoms.move_block.css('background-color', '#5cb85c'); this.htmlDoms.left_bar.css({'color': '#4cae4c', 'border-color': '#5cb85c', 'background-color': '#fff' }); this.htmlDoms.icon.css('color', '#fff'); this.htmlDoms.icon.removeClass('icon-right'); this.htmlDoms.icon.addClass('icon-check'); this.htmlDoms.refresh.hide(); this.htmlDoms.move_block.unbind('mousedown'); this.htmlDoms.move_block.unbind('touchstart'); this.$element.find('.verify-msg:eq(1)').text('Verification successful'); this.options.success(); }else { this.htmlDoms.move_block.css('background-color', '#d9534f'); this.htmlDoms.left_bar.css('border-color', '#d9534f'); this.htmlDoms.icon.css('color', '#fff'); this.htmlDoms.icon.removeClass('icon-right'); this.htmlDoms.icon.addClass('icon-close'); setTimeout(function () { _this.htmlDoms.move_block.animate({'left':'0px'}, 'fast'); _this.htmlDoms.left_bar.animate({'width': '40px'}, 'fast'); _this.htmlDoms.left_bar.css({'border-color': '#ddd'}); _this.htmlDoms.move_block.css('background-color', '#fff'); _this.htmlDoms.icon.css('color', '#000'); _this.htmlDoms.icon.removeClass('icon-close'); _this.htmlDoms.icon.addClass('icon-right'); _this.$element.find('.verify-msg:eq(0)').text('Slide right to unlock'); }, 400); this.options.error(); } } this.status = false; } }, resetSize : function(obj) { var img_width,img_height,bar_width,bar_height; //Image width, height, mobile bar width, height var parentWidth = obj.$element.parent().width() || $(window).width(); var parentHeight = obj.$element.parent().height() || $(window).height(); if(obj.options.imgSize.width.indexOf('%')!= -1){ img_width = parseInt(obj.options.imgSize.width)/100 * parentWidth + 'px'; }else { img_width = obj.options.imgSize.width; } if(obj.options.imgSize.height.indexOf('%')!= -1){ img_height = parseInt(obj.options.imgSize.height)/100 * parentHeight + 'px'; }else { img_height = obj.options.imgSize.height; } if(obj.options.barSize.width.indexOf('%')!= -1){ bar_width = parseInt(obj.options.barSize.width)/100 * parentWidth + 'px'; }else { bar_width = obj.options.barSize.width; } if(obj.options.barSize.height.indexOf('%')!= -1){ bar_height = parseInt(obj.options.barSize.height)/100 * parentHeight + 'px'; }else { bar_height = obj.options.barSize.height; } return {img_width : img_width, img_height : img_height, bar_width : bar_width, bar_height : bar_height}; }, //Random birth point randSet: function() { var rand1 = Math.floor(Math.random()*9+1); var rand2 = Math.floor(Math.random()*9+1); var top = rand1 * parseInt(this.setSize.img_height)/15 + parseInt(this.setSize.img_height) * 0.1; var left = rand2 * parseInt(this.setSize.img_width)/15 + parseInt(this.setSize.img_width) * 0.1; this.$element.find('.verify-img-panel').css('margin-bottom', this.options.vSpace + 'px'); this.$element.find('.verify-gap').css({'top': top, 'left': left}); this.$element.find('.verify-sub-block').css({'top':'-'+(parseInt(this.setSize.img_height)- top + this.options.vSpace + 2)+'px', 'background-image': 'url(images/'+this.options.imgName[this.img_rand]+')', 'background-size': this.setSize.img_width + ' '+ this.setSize.img_height,'background-position-y': '-'+top+ 'px', 'background-position-x': '-'+left+'px'}); }, //Refresh refresh: function() { this.randSet(); this.img_rand = Math.floor(Math.random() * this.options.imgName.length); //Random background image this.$element.find('.verify-img-panel').css({'background': 'url(images/'+this.options.imgName[this.img_rand]+')', 'background-size': this.setSize.img_width + ' '+ this.setSize.img_height}); this.$element.find('.verify-sub-block').css({'background-image': 'url(images/'+this.options.imgName[this.img_rand]+')', 'background-size': this.setSize.img_width + ' '+ this.setSize.img_height}); }, //Get the left value getLeft: function(node) { var left = $(node).offset().left; // var nowPos = node.offsetParent; // // while(nowPos != null) { // left += $(nowPos).offset().left; // nowPos = nowPos.offsetParent; // } return left; } }; //Define the Points constructor var Points = function(ele, opt) { this.$element = ele, this.defaults = { defaultNum : 4, //Default number of characters checkNum : 3, //Verified number of characters vSpace : 5, //Interval imgName : ['1.jpg', '2.jpg'], imgSize : { width: '400px', height: '200px', }, barSize : { width : '400px', height : '40px', }, ready : function(){}, success : function(){}, error : function(){} }, this.options = $.extend({}, this.defaults, opt) }; //Define the Points method Points.prototype = { init : function() { var _this = this; //Load the page _this.loadDom(); _this.refresh(); _this.options.ready(); this.$element[0].onselectstart = document.body.ondrag = function(){ return false; }; //Click event comparison _this.$element.find('.verify-img-panel canvas').on('click', function(e) { _this.checkPosArr.push(_this.getMousePos(this, e)); if(_this.num == _this.options.checkNum) { _this.num = _this.createPoint(_this.getMousePos(this, e)); setTimeout(function () { var flag = _this.comparePos(_this.fontPos, _this.checkPosArr); if(flag == false) { //Verification failed _this.options.error(); _this.$element.find('.verify-bar-area').css({'color': '#d9534f', 'border-color': '#d9534f'}); _this.$element.find('.verify-msg').text('Verification failed'); setTimeout(function () { _this.$element.find('.verify-bar-area').css({'color': '#000','border-color': '#ddd'}); _this.refresh(); }, 400); }else { //Verification successful _this.$element.find('.verify-bar-area').css({'color': '#4cae4c', 'border-color': '#5cb85c'}); _this.$element.find('.verify-msg').text('Verification successful'); _this.$element.find('.verify-refresh').hide(); _this.$element.find('.verify-img-panel').unbind('click'); _this.options.success(); } }, 400); } if(_this.num < _this.options.checkNum) { _this.num = _this.createPoint(_this.getMousePos(this, e)); } }); //Refresh_this.$element.find('.verify-refresh').on('click', function() { _this.refresh(); }); }, //Load the page loadDom : function() { this.fontPos = []; //Selected coordinate information this.checkPosArr = []; //Coordinates clicked by the user this.num = 1; //Number of clicks this.img_rand = Math.floor(Math.random() * this.options.imgName.length); //Random background image var panelHtml = ''; var tmpHtml = ''; this.setSize = Slide.prototype.resetSize(this); //Reset width and height panelHtml += '<div class="verify-img-panel"><div class="verify-refresh" style="z-index:9999"><i class="iconfont icon-refresh"></i></div><canvas width="'+this.setSize.img_width+'" height="'+this.setSize.img_height+'"></canvas></div><div class="verify-bar-area"><span class="verify-msg"></span></div>'; this.$element.append(panelHtml); this.htmlDoms = { img_panel : this.$element.find('.verify-img-panel'), bar_area : this.$element.find('.verify-bar-area'), msg : this.$element.find('.verify-msg'), }; this.htmlDoms.img_panel.css({'width': this.setSize.img_width, 'height': this.setSize.img_height, 'background-size' : this.setSize.img_width + ' ' + this.setSize.img_height, 'margin-bottom': this.options.vSpace + 'px'}); this.htmlDoms.bar_area.css({'width': this.options.barSize.width, 'height': this.options.barSize.height, 'line-height': this.options.barSize.height}); }, //Draw the composite image drawImg : function(obj, img) { //Prepare canvas environment var canvas = this.$element.find('canvas')[0]; //var canvas=document.getElementById("myCanvas"); var ctx = canvas.getContext("2d"); // Draw the image ctx.drawImage(img,0,0, parseInt(this.setSize.img_width), parseInt(this.setSize.img_height)); // Draw watermark var fontSizeArr = ['italic small-caps bold 20px microsoft yahei', 'small-caps normal 25px arial', '34px microsoft yahei']; var fontStr = 'The universe is vast and boundless, the sun and the moon wax and wane, the stars are spread out, cold comes and summer goes, autumn harvests, winter stores, leap years become a year, the rhythm of the sun rises, clouds rise, rain and dew turn into frost, gold grows in Lishui, jade emerges from Kungang, the sword is called Juque, pearls are called night-light, fruits are precious, pear, mustard, ginger, sea, salty river, light scales, hidden feathers, flying dragons, fire emperors, bird officials, the emperor first created characters, and then wore clothes, gave up the throne and gave up the country, there were Yu, Tao, Tang, condolences to the people, punishing the criminals, Zhou Fa, Yin Tang, sitting in the court, asking for the way, Chuigong Pingzhang, Aiyu Li, the first minister, Furong Qiang, Xiaer, and the body led the guests to return to the king'; //Unrepeated Chinese characters var fontChars = []; var avg = Math.floor(parseInt(this.setSize.img_width)/(parseInt(this.options.defaultNum)+1)); var tmp_index = ''; var color2Num = Math.floor(Math.random() * 5); for(var i = 1; i <= this.options.defaultNum; i++) { fontChars[i-1] = this.getChars(fontStr, fontChars); tmp_index = Math.floor(Math.random()*3); ctx.font = fontSizeArr[tmp_index]; ctx.fillStyle = _code_color2[color2Num]; if (Math.floor(Math.random() * 2) == 1) { var tmp_y = Math.floor(parseInt(this.setSize.img_height)/2) + tmp_index*20 + 20; }else { var tmp_y = Math.floor(parseInt(this.setSize.img_height)/2) - tmp_index*20; } ctx.fillText(fontChars[i-1],avg * i, tmp_y); this.fontPos[i-1] = {'char': fontChars[i-1], 'x': avg * i, 'y': tmp_y}; } for(var i = 0; i < (this.options.defaultNum - this.options.checkNum); i++) { this.shuffle(this.fontPos).pop(); } var msgStr = ''; for(var i = 0; i < this.fontPos.length; i++) { msgStr += this.fontPos[i].char + ','; } this.htmlDoms.msg.text('Please click in order【' + msgStr.substring(0,msgStr.length-1) + '】'); return this.fontPos; }, //Get coordinates getMousePos :function(obj, event) { var e = event || window.event; var scrollX = document.documentElement.scrollLeft || document.body.scrollLeft; var scrollY = document.documentElement.scrollTop || document.body.scrollTop; var x = e.clientX - ($(obj).offset().left - $(window).scrollLeft()); var y = e.clientY - ($(obj).offset().top - $(window).scrollTop()); return {'x': x, 'y': y}; }, //Recursive deduplication getChars : function (fontStr, fontChars) { var tmp_rand = parseInt(Math.floor(Math.random() * fontStr.length)); if(tmp_rand > 0) { tmp_rand = tmp_rand - 1; } tmp_char = fontStr.charAt(tmp_rand); if($.inArray(tmp_char, fontChars) == -1) { return tmp_char; }else { return Points.prototype.getChars(fontStr, fontChars); } }, // shuffle array shuffle: function(arr) { var m = arr.length, i; while (m) { i = (Math.random() * m--) >>> 0; [arr[m], arr[i]] = [arr[i], arr[m]] } return arr; }, //Create coordinate point createPoint : function (pos) { this.htmlDoms.img_panel.append('<div class="point-area" style="background-color:#1abd6c;color:#fff;z-index:9999;width:30px;height:30px;text-align:center;line-height:30px;border-radius: 50%;position:absolute;top:'+parseInt(pos.y-10)+'px;left:'+parseInt(pos.x-10)+'px;">'+this.num+'</div>'); return ++this.num; }, //Compare coordinate points comparePos : function (fontPos, checkPosArr) { var flag = true; for(var i = 0; i < fontPos.length; i++) { if(!(parseInt(checkPosArr[i].x) + 40 > fontPos[i].x && parseInt(checkPosArr[i].x) - 40 < fontPos[i].x && parseInt(checkPosArr[i].y) + 40 > fontPos[i].y && parseInt(checkPosArr[i].y) - 40 < fontPos[i].y)) { flag = false; break; } } return flag; }, //Refresh refresh: function() { var _this = this; this.$element.find('.point-area').remove(); this.fontPos = []; this.checkPosArr = []; this.num = 1; this.img_rand = Math.floor(Math.random() * this.options.imgName.length); //Random background image var img = new Image(); img.src = 'images/' + this.options.imgName[this.img_rand]; // Loading completes and starts drawing $(img).on('load', function(e) { this.fontPos = _this.drawImg(_this, this); }); }, }; //Use the codeVerify object in the plugin $.fn.codeVerify = function(options, callbacks) { var code = new Code(this, options); code.init(); }; //Use the slideVerify object in the plugin $.fn.slideVerify = function(options, callbacks) { var slide = new Slide(this, options); slide.init(); }; //Use clickVerify object in plugin $.fn.pointsVerify = function(options, callbacks) { var points = new Points(this, options); points.init(); }; })(jQuery, window, document); This concludes this article about various types of jQuery web page verification code plug-in code examples. For more related jQuery web page verification code plug-in content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Example of using JS to determine whether an element is an array
>>: JavaScript canvas to achieve raindrop effects
1. forEach() is similar to map(). It also applies...
<br />Previous article: Web Design Tutorial ...
1. Introduction to mysqlbackup mysqlbackup is the...
1. Command Introduction The passwd command is use...
Table of contents 1. Install dependencies 2. Conf...
In the previous blog, Xiao Xiong updated the meth...
This article example shares the specific code of ...
<br />Reading is a very important part of th...
IE10 provides a quick clear button (X icon) and a ...
1. Why does nginx use gzip? 1. The role of compre...
#docker search #docker pull portainer 1. Download...
Table of contents 1. Common mistakes made by begi...
In order to make the page display consistent betwe...
You can easily input Chinese and get Chinese outp...
A dynamic clock demo based on Canvas is provided ...