电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

原生js生成圖片驗(yàn)證碼

瀏覽:133日期:2024-04-17 15:25:11

本文實(shí)例為大家分享了js生成圖片驗(yàn)證碼的具體代碼,供大家參考,具體內(nèi)容如下

html代碼

<!DOCTYPE html><html> <head> <meta charset='UTF-8'> <title>圖形驗(yàn)證碼</title> </head> <body> <div style='width: 200px;height: 50px;'></div> <input type='text' value='' placeholder='請(qǐng)輸入驗(yàn)證碼'/><button id='my_button'>驗(yàn)證</button> </body> <script src='http://www.hdgsjgj.cn/js/picCode.js'></script> <script> var verifyCode = new GVerify('v_container'); document.getElementById('my_button').onclick = function(){ var res = verifyCode.validate(document.getElementById('code_input').value); if(res){ alert('驗(yàn)證正確'); }else{ alert('驗(yàn)證碼錯(cuò)誤'); } } </script></html>

js

!(function(window, document) { var size = 5;//設(shè)置驗(yàn)證碼長度 function GVerify(options) { //創(chuàng)建一個(gè)圖形驗(yàn)證碼對(duì)象,接收options對(duì)象為參數(shù) this.options = { //默認(rèn)options參數(shù)值 id: '', //容器Id canvasId: 'verifyCanvas', //canvas的ID width: '100', //默認(rèn)canvas寬度 height: '30', //默認(rèn)canvas高度 type: 'blend', //圖形驗(yàn)證碼默認(rèn)類型blend:數(shù)字字母混合類型、number:純數(shù)字、letter:純字母 code: '', } if(Object.prototype.toString.call(options) == '[object Object]'){//判斷傳入?yún)?shù)類型 for(var i in options) { //根據(jù)傳入的參數(shù),修改默認(rèn)參數(shù)值 this.options[i] = options[i]; } }else{ this.options.id = options; } this.options.numArr = '0,1,2,3,4,5,6,7,8,9'.split(','); this.options.letterArr = getAllLetter(); this._init(); this.refresh(); } GVerify.prototype = { /**版本號(hào)**/ version: ’1.0.0’, /**初始化方法**/ _init: function() { var con = document.getElementById(this.options.id); var canvas = document.createElement('canvas'); this.options.width = con.offsetWidth > 0 ? con.offsetWidth : '100'; this.options.height = con.offsetHeight > 0 ? con.offsetHeight : '30'; canvas.id = this.options.canvasId; canvas.width = this.options.width; canvas.height = this.options.height; canvas.style.cursor = 'pointer'; canvas.innerHTML = '您的瀏覽器版本不支持canvas'; con.appendChild(canvas); var parent = this; canvas.onclick = function(){ parent.refresh(); } }, /**生成驗(yàn)證碼**/ refresh: function() { this.options.code = ''; var canvas = document.getElementById(this.options.canvasId); if(canvas.getContext) { var ctx = canvas.getContext(’2d’); }else{ return; } ctx.textBaseline = 'middle'; ctx.fillStyle = randomColor(180, 240); ctx.fillRect(0, 0, this.options.width, this.options.height); if(this.options.type == 'blend') { //判斷驗(yàn)證碼類型 var txtArr = this.options.numArr.concat(this.options.letterArr); } else if(this.options.type == 'number') { var txtArr = this.options.numArr; } else { var txtArr = this.options.letterArr; } for(var i = 1; i <=size; i++) { var txt = txtArr[randomNum(0, txtArr.length)]; this.options.code += txt; ctx.font = randomNum(this.options.height/2, this.options.height) + ’px SimHei’; //隨機(jī)生成字體大小 ctx.fillStyle = randomColor(50, 160); //隨機(jī)生成字體顏色 ctx.shadowOffsetX = randomNum(-3, 3); ctx.shadowOffsetY = randomNum(-3, 3); ctx.shadowBlur = randomNum(-3, 3); ctx.shadowColor = 'rgba(0, 0, 0, 0.3)'; var x = this.options.width / (size+1) * i; var y = this.options.height / 2; var deg = randomNum(-30, 30); /**設(shè)置旋轉(zhuǎn)角度和坐標(biāo)原點(diǎn)**/ ctx.translate(x, y); ctx.rotate(deg * Math.PI / 180); ctx.fillText(txt, 0, 0); /**恢復(fù)旋轉(zhuǎn)角度和坐標(biāo)原點(diǎn)**/ ctx.rotate(-deg * Math.PI / 180); ctx.translate(-x, -y); } /**繪制干擾線**/ for(var i = 0; i < 4; i++) { ctx.strokeStyle = randomColor(40, 180); ctx.beginPath(); ctx.moveTo(randomNum(0, this.options.width), randomNum(0, this.options.height)); ctx.lineTo(randomNum(0, this.options.width), randomNum(0, this.options.height)); ctx.stroke(); } /**繪制干擾點(diǎn)**/ for(var i = 0; i < this.options.width/4; i++) { ctx.fillStyle = randomColor(0, 255); ctx.beginPath(); ctx.arc(randomNum(0, this.options.width), randomNum(0, this.options.height), 1, 0, 2 * Math.PI); ctx.fill(); } }, /**驗(yàn)證驗(yàn)證碼**/ validate: function(code){ var code = code.toLowerCase(); var v_code = this.options.code.toLowerCase(); if(code == v_code){ return true; }else{ this.refresh(); return false; } } } /**生成字母數(shù)組**/ function getAllLetter() { var letterStr = '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'; return letterStr.split(','); } /**生成一個(gè)隨機(jī)數(shù)**/ function randomNum(min, max) { return Math.floor(Math.random() * (max - min) + min); } /**生成一個(gè)隨機(jī)色**/ function randomColor(min, max) { var r = randomNum(min, max); var g = randomNum(min, max); var b = randomNum(min, max); return 'rgb(' + r + ',' + g + ',' + b + ')'; } window.GVerify = GVerify;})(window, document);

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | 校服厂家,英伦校服定做工厂,园服生产定制厂商-东莞市艾咪天使校服 | 动物解剖台-成蚊接触筒-标本工具箱-负压实验台-北京哲成科技有限公司 | 车间除尘设备,VOCs废气处理,工业涂装流水线,伸缩式喷漆房,自动喷砂房,沸石转轮浓缩吸附,机器人喷粉线-山东创杰智慧 | 儋州在线-儋州招聘找工作、找房子、找对象,儋州综合生活信息门户! | 名律网-法律问题咨询-找律师-法律知识| 超细|超微气流粉碎机|气流磨|气流分级机|粉体改性机|磨粉机|粉碎设备-山东埃尔派粉体科技 | 智慧钢琴-电钢琴-便携钢琴-数码钢琴-深圳市特伦斯乐器有限公司 | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 锥形螺带干燥机(新型耙式干燥机)百科-常州丰能干燥工程 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 合肥白癜风医院_[治疗白癜风]哪家好_合肥北大白癜风医院 | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 | 杭州厂房降温,车间降温设备,车间通风降温,厂房降温方案,杭州嘉友实业爽风品牌 | 活性氧化铝球|氧化铝干燥剂|分子筛干燥剂|氢氧化铝粉-淄博同心材料有限公司 | 山东齐鲁漆业有限公司【官网】-工业漆专业生产厂家 | 食品无尘净化车间,食品罐装净化车间,净化车间配套风淋室-青岛旭恒洁净技术有限公司 | 车辆定位管理系统_汽车GPS系统_车载北斗系统 - 朗致物联 | 电机保护器-电动机综合保护器-上海硕吉电器有限公司 | 书法培训-高考书法艺考培训班-山东艺霖书法培训凭实力挺进央美 | 酒瓶_酒杯_玻璃瓶生产厂家_徐州明政玻璃制品有限公司 | 氧化铝球_高铝球_氧化铝研磨球-淄博誉洁陶瓷新材料有限公司 | 不锈钢散热器,冷却翅片管散热器厂家-无锡市烨晟化工装备科技有限公司 | 合肥制氮机_合肥空压机厂家_安徽真空泵-凯圣精机 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 产业规划_产业园区规划-产业投资选址及规划招商托管一体化服务商-中机院产业园区规划网 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 杭州货架订做_组合货架公司_货位式货架_贯通式_重型仓储_工厂货架_货架销售厂家_杭州永诚货架有限公司 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 净化车间装修_合肥厂房无尘室设计_合肥工厂洁净工程装修公司-安徽盛世和居装饰 | 环保袋,无纺布袋,无纺布打孔袋,保温袋,环保袋定制,环保袋厂家,环雅包装-十七年环保袋定制厂家 | 刘秘书_你身边专业的工作范文写作小秘书 | 心得体会网_心得体会格式范文模板| 湖南印刷厂|长沙印刷公司|画册印刷|挂历印刷|台历印刷|杂志印刷-乐成印刷 | 不锈钢列管式冷凝器,换热器厂家-无锡飞尔诺环境工程有限公司 | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 | 油液红外光谱仪-油液监测系统-燃油嗅探仪-上海冉超光电科技有限公司 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 成都热收缩包装机_袖口式膜包机_高速塑封机价格_全自动封切机器_大型套膜机厂家 | 液氨泵,液化气泵-淄博「亚泰」燃气设备制造有限公司 | 高压贴片电容|贴片安规电容|三端滤波器|风华电容代理南京南山 |