生成用户登录图形验证码的过程可以通过几个步骤来实现,包括创建画布,生成随机验证码文本,将验证码文本绘制到画布上,以及添加一些噪点和线条来增加复杂性。
HTML
首先,在HTML文件中创建一个<canvas>
元素和一个按钮来触发验证码的生成:
<body><div class="code"><!-- 用户名输入框 -->用户名:<input type="text"><br><!-- 密码输入框 -->密 码:<input type="text"><br><!-- 验证码输入框 -->验证码:<input type="text" value="" id="inputValue" placeholder="请输入验证码(不区分大小写)"><!-- canvas画布框 --><canvas id="c1" width="100" height="30" style="border:1px solid black"></canvas><br><!-- 登录按钮 --><button id="btn">登录</button></div></body>
JavaScript
然后,引入jQuery
<script src="./js/jquery-3.7.1.js"></script>
创建一个函数来把随机验证码放到画布上
// 封装一个把随机验证码放在画布上function draw(showNum) {}
然后获取canvas的相关信息
// 获取canvasvar canvas = $("#c1")
// 获取一个 <canvas> 元素的2D渲染上下文var ctx = canvas[0].getContext("2d")
const ctx = canvas.getContext('2d');
这行代码的作用是获取一个HTML5 <canvas>
元素的2D渲染上下文。一旦你有了这个上下文,你就可以使用各种绘图方法来绘制形状、路径、文本、图像等内容到 <canvas>
元素上。
接着获取画布的宽度
var canvas_width = canvas.width()var canvas_height = canvas.height()
清空之前的内容,从0,0开始绘制,设置矩形宽高
ctx.clearRect(0, 0, canvas_width, canvas_height)
ctx.clearRect(0, 0, canvas_width, canvas_height)
是用来清空画布的。在 Canvas 绘图上下文中,这行代码将清除整个画布,也就是说,画布上的所有内容都将被删除。
这个方法的参数是左上角的 x 坐标,左上角的 y 坐标,宽度和高度。在这里,(0, 0) 是起始位置(即左上角),canvas_width
和 canvas_height
分别是画布的宽度和高度。因此,这个方法将清除整个画布。
在绘图或动画之前,通常会先调用这个方法来清空画布,以便从头开始绘制
开始绘制
声明一个变量为a-z小写字母,A-Z大写字母,1-9的数字的字符串
var scode ="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,1,2,3,4,5,6,7,8,9,"
接着,使用 split(",")
方法将这个字符串按照逗号分隔成一个数组,并将结果赋值给 arrCode
。
同时声明一个变量等于这个数组的长度
var arrCode = scode.split(",")var arrLength = arrCode.length
使用 Math.random()
和 Math.floor()
从 arrCode
数组中随机选择一个索引。
var index = Math.floor(Math.random() * arrCode.length)
随机一个字符
var txt = arrCode[index] //随机一个字符
将字符转化为小写存入验证码数组
showNum[i] = txt.toLowerCase() //转化为小写存入验证码数组
开始控制字符绘制位置
// 开始控制字符的绘制位置var x = 10 + 20 * i //每一个验证码绘制的起始点x坐标var y = 20 + Math.random() * 8 // 起始点y坐标ctx.font = "bold 20px 微软雅黑"
旋转字符
// 开始旋转字符var deg = Math.random * -0.5
倾斜字符
// canvas 要实现绘制内容具有倾斜的效果,必须先平移,目的是把旋转点移动到绘制内容的地方ctx.translate(x, y)ctx.rotate(deg)
设置随机颜色
// 设置绘制的随机颜色ctx.fillStyle = randomColor()ctx.fillText(txt, 0, 0)
还原canvas
// 把canvas复原ctx.rotate(-deg)ctx.translate(-x, -y)
开始一个新的路径
// 循环判断i小于30for (var i = 0; i < 30; i++) {// 如果i小于5if (i < 5) {// 绘制线ctx.strokeStyle = randomColor()// 开始路径ctx.beginPath()// 在 Canvas 绘图上下文中将当前路径的起始点移动到画布上的一个随机位置。ctx.moveTo(Math.random() * canvas_width, Math.random() * canvas_height)// 在 Canvas 绘图上下文中从当前路径的最后一个点绘制一条直线到一个新的随机位置。ctx.lineTo(Math.random() * canvas_width, Math.random() * canvas_height)// 绘制路径ctx.stroke()}// 绘制点ctx.strokeStyle = randomColor()ctx.beginPath()var x = Math.random() * canvas_widthvar y = Math.random() * canvas_heightctx.moveTo(x, y)ctx.lineTo(x + 1, y + 1)ctx.stroke()}
随机一个颜色
// 随机颜色生成一个随机的 RGB 颜色值function randomColor() {var r = Math.floor(Math.random() * 256)var g = Math.floor(Math.random() * 256)var b = Math.floor(Math.random() * 256)return `rgb(${r},${g},${b})`}
然后调用这个封装的函数
$(function() {// 存放随机的验证码var showNum = []draw(showNum)$("#c1").click(function() {draw(showNum)})$("#btn").click(function() {var s = $("#inputValue").val().toLowerCase()var s1 = showNum.join("")if (s == s1) {alert("提交成功")} else {alert("验证码错误")}draw(showNum)})
整体部分:
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><script src="./js/jquery-3.7.1.js"></script><title>Document</title><style>input {width: 200px;height: 32px;border: 1px solid #000;box-sizing: border-box;margin-top: 2px;}#c1 {vertical-align: middle;box-sizing: border-box;cursor: pointer;}#btn {display: block;margin-top: 20px;height: 32px;font-size: 16px;}</style></head><body><div class="code"><!-- 用户名输入框 -->用户名:<input type="text"><br><!-- 密码输入框 -->密 码:<input type="text"><br><!-- 验证码输入框 -->验证码:<input type="text" value="" id="inputValue" placeholder="请输入验证码(不区分大小写)"><!-- canvas画布框 --><canvas id="c1" width="100" height="30" style="border:1px solid black"></canvas><br><!-- 登录按钮 --><button id="btn">登录</button></div></body><script>$(function() {// 存放随机的验证码var showNum = []draw(showNum)$("#c1").click(function() {draw(showNum)})$("#btn").click(function() {var s = $("#inputValue").val().toLowerCase()var s1 = showNum.join("")if (s == s1) {alert("提交成功")} else {alert("验证码错误")}draw(showNum)})// 封装一个把随机验证码放在画布上function draw(showNum) {// 获取canvasvar canvas = $("#c1")// 获取一个 <canvas> 元素的2D渲染上下文var ctx = canvas[0].getContext("2d")// 获取画布的宽高var canvas_width = canvas.width()var canvas_height = canvas.height()// 清空之前绘制的内容// 0,0清空的起始坐标// 矩形的宽高ctx.clearRect(0, 0, canvas_width, canvas_height)// 开始绘制var scode ="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,1,2,3,4,5,6,7,8,9,"var arrCode = scode.split(",")var arrLength = arrCode.length//循环判断i是否小于4for (var i = 0; i < 4; i++) {// 使用 Math.random() 和 Math.floor() 从 arrCode 数组中随机选择一个索引。var index = Math.floor(Math.random() * arrCode.length)var txt = arrCode[index] //随机一个字符showNum[i] = txt.toLowerCase() //转化为小写存入验证码数组// 开始控制字符的绘制位置var x = 10 + 20 * i //每一个验证码绘制的起始点x坐标var y = 20 + Math.random() * 8 // 起始点y坐标ctx.font = "bold 20px 微软雅黑"// 开始旋转字符var deg = Math.random * -0.5// canvas 要实现绘制内容具有倾斜的效果,必须先平移,目的是把旋转点移动到绘制内容的地方ctx.translate(x, y)ctx.rotate(deg)// 设置绘制的随机颜色ctx.fillStyle = randomColor()ctx.fillText(txt, 0, 0)// 把canvas复原ctx.rotate(-deg)ctx.translate(-x, -y)}// 循环判断i小于30for (var i = 0; i < 30; i++) {// 如果i小于5if (i < 5) {// 绘制线ctx.strokeStyle = randomColor()// 开始路径ctx.beginPath()// 在 Canvas 绘图上下文中将当前路径的起始点移动到画布上的一个随机位置。ctx.moveTo(Math.random() * canvas_width, Math.random() * canvas_height)// 在 Canvas 绘图上下文中从当前路径的最后一个点绘制一条直线到一个新的随机位置。ctx.lineTo(Math.random() * canvas_width, Math.random() * canvas_height)// 绘制路径ctx.stroke()}// 绘制点ctx.strokeStyle = randomColor()ctx.beginPath()var x = Math.random() * canvas_widthvar y = Math.random() * canvas_heightctx.moveTo(x, y)ctx.lineTo(x + 1, y + 1)ctx.stroke()}}// 随机颜色生成一个随机的 RGB 颜色值function randomColor() {var r = Math.floor(Math.random() * 256)var g = Math.floor(Math.random() * 256)var b = Math.floor(Math.random() * 256)return `rgb(${r},${g},${b})`}})</script>
</html>