本文实例为大家分享了利用canvas绘制图形验证码的具体代码,供大家参考,具体内容如下
思路:通过随机获取指定字符串的指定数的字符,通过canvas绘制出来
返回指定范围的随机整数
1
2
3
4
5
6
7
8
9
10
11
12
|
//指定范围的随机函数:返回指定范围内的随机整数
function rand(min, max) {
/*
max=10
min=1
Math.random()=0 最小取到1
Math.random()=0.9999*10=Math.floor(9.9)=>+1=10
*/
return Math.floor(Math.random() * (max - min + 1)) + min;
}
|
返回指定数量的随机字符串
1
2
3
4
5
6
7
8
9
10
|
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
}
|
绘制图形
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
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);
}
|
鼠标点击更新验证码
1
2
3
|
document.querySelector( 'canvas' ).addEventListener( 'click' , function () {
verify( 'canvas' )
})
|
完整代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
<!DOCTYPE html>
< html lang = "en" >
< head >
< meta charset = "UTF-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< title >绘制图形验证码</ title >
< style >
canvas {
border: 1px solid red;
}
</ style >
</ head >
< body >
< canvas width = "160" height = "50" ></ canvas >
</ body >
< script >
verify('canvas')
document.querySelector('canvas').addEventListener('click', function () {
verify('canvas')
})
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)
//字体样式的属性要遵循css中的书写顺序
ctx.font = '900 24px 宋体'
//设置字体颜色
ctx.fillStyle = '#FFF';
//绘制文字
ctx.fillText(code, 20, 30);
}
//指定范围的随机函数:返回指定范围内的随机整数
function rand(min, max) {
/*
max=10
min=1
Math.random()=0 最小取到1
Math.random()=0.9999*10=Math.floor(9.9)=>+1=10
*/
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
}
// console.log(randStr(6))
</script>
</ html >
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_43615701/article/details/108694085