JS如何实现图片验证码功能
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,本篇内容主要讲解"JS如何实现图片验证码功能",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"JS如何实现图片验证码功能"吧!1. html代码<%@ pag
千家信息网最后更新 2025年11月07日JS如何实现图片验证码功能
本篇内容主要讲解"JS如何实现图片验证码功能",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"JS如何实现图片验证码功能"吧!
1. html代码
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
2. 引入gVerify.js
!(function(window, document) { function GVerify(options) { // 创建一个图形验证码对象,接收options对象为参数 this.options = { // 默认options参数值 id: "", // 容器Id canvasId: "verifyCanvas", // canvas的ID width: "100", // 默认canvas宽度 height: "30", // 默认canvas高度 type: "blend", // 图形验证码默认类型blend:数字字母混合类型、number:纯数字、letter:纯字母 code: "" } if(Object.prototype.toString.call(options) == "[object Object]"){// 判断传入参数类型 for(var i in options) { // 根据传入的参数,修改默认参数值 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 = { /** 版本号* */ 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[xss_clean] = "您的浏览器版本不支持canvas"; con.appendChild(canvas); var parent = this; canvas.onclick = function(){ parent.refresh(); } }, /** 生成验证码* */ 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") { // 判断验证码类型 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 <= 4; i++) { var txt = txtArr[randomNum(0, txtArr.length)]; this.options.code += txt; ctx.font = randomNum(this.options.height/2, this.options.height) + 'px SimHei'; // 随机生成字体大小 ctx.fillStyle = randomColor(50, 160); // 随机生成字体颜色 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 / 5 * i; var y = this.options.height / 2; var deg = randomNum(-30, 30); /** 设置旋转角度和坐标原点* */ ctx.translate(x, y); ctx.rotate(deg * Math.PI / 180); ctx.fillText(txt, 0, 0); /** 恢复旋转角度和坐标原点* */ 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(); } /** 绘制干扰点* */ 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(); } }, /** 验证验证码* */ validate: function(code){ var code = code.toLowerCase(); var v_code = this.options.code.toLowerCase(); if(code == v_code){ return true; }else{ return false; } } } /** 生成字母数组* */ 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(","); } /** 生成一个随机数* */ function randomNum(min, max) { return Math.floor(Math.random() * (max - min) + min); } /** 生成一个随机色* */ 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);3. 效果图
到此,相信大家对"JS如何实现图片验证码功能"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
验证
生成
参数
类型
功能
图片
字母
内容
原点
图形
坐标
字体
对象
数字
方法
版本
角度
学习
干扰
实用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库导出工具
深圳3u服务器散热器多少钱
苹果手机共享服务器连接不上
胶州app定制软件开发
sql往数据库导入
英业达软件开发面试内容
无锡电商软件开发供应商家
lol网络安全证书过期
黄浦区银联数据库销售
软件开发一定要连接外网嘛
外文数据库怎么设置
县委组织部网络安全自查总结
文明重启服务器被踢后还能找到
监控管理服务器怎么套定额
网络安全性要求包括
软件开发体系架构
贵州省自然灾害数据库
安徽企业网络技术咨询简介
淮阴师范学院数据库期中考
ssh 项目查不到数据库
锐捷网络技术支持工程师工资
提出网络安全
sql数据库查询成绩平均分语句
最终幻想转移服务器
Linux服务器查看显卡日志
数据库与网站分离技术
服务器搭建网站收集数据
静安区数据软件开发协议
洛阳市翔度网络技术有限公司
sql数据库表怎么复制