本文实例为大家分享了利用canvas绘制图形验证码的具体代码,供大家参考,具体内容如下
思路:通过随机获取指定字符串的指定数的字符,通过canvas绘制出来
返回指定范围的随机整数
//指定范围的随机函数:返回指定范围内的随机整数
function rand(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
返回指定数量的随机字符串
function randStr(count) {
var str = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
var code = '';
for (var i = 0; i < count; i++) {
var index = rand(0, str.length - 1)//必须减一否则会出现下标越界
code += str.charAt(index) + ' ';
}
return code
}
绘制图形
function verify(selector) {
//获取canvas的dom对象
var cas = document.querySelector(selector);
//获取上下文对象
var ctx = cas.getContext('2d');
//指定接收的字符串
var code = randStr(5);
//绘制矩形,作背景色
ctx.fillStyle = 'orange';
//绘制实心矩形
ctx.fillRect(0, 0, 160, 50)
//文字居中
// ctx.textAlign = 'left'
//字体样式的属性要遵循css中的书写顺序
ctx.font = '900 24px 宋体'
//设置字体颜色
ctx.fillStyle = '#FFF';
//绘制文字
ctx.fillText(code, 20, 30);
}
鼠标点击更新验证码
document.querySelector('canvas').addEventListener('click', function () {
verify('canvas')
})
完整代码
绘制图形验证码 canvas { border: 1px solid red; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。



