本文实例为大家分享了js+h5 canvas实现图片验证码的具体代码,供大家参考,具体内容如下
实现效果
一、使用技术
原生js技术+html5 canvas画图
利用Math.random()函数随机生成 颜色 字符串 及障碍物
点击 验证码可变更验证码图案
二、使用步骤
1.html+css
代码如下(示例):
- <div class="login_code_box">
- <div class="login_code">
- <input type="text" name="login_code" id="login_code" placeholder="请输入验证码">
- </div>
- <canvas id="canvas" >
- </canvas>
- <!-- <img src="" alt="" title="看不清?单击此处刷新" class="login_code_img" > -->
- </div>
1
2
3
4
5
6
7
8
|
#canvas{
width : 130px ;
height : 45px ;
display : inline- block ;
border : 1px solid #c9c9c9 ;
border-radius: 5px ;
}
|
2.js
代码如下(示例):
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
|
//验证码生成
let canvas=document.getElementById( 'canvas' ) //画布对象
let show_num=[] //装验证码的数组
//产生随机颜色
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 draw(show_num){
let canvas_clientWidth=document.getElementById( 'canvas' ).clientWidth //画布长度
let canvas_clientHeight=document.getElementById( 'canvas' ).clientHeight //画布高度
let context = canvas.getContext( "2d" ) //画布环境 创建 context 对象:
canvas.width=canvas_clientWidth
canvas.height=canvas_clientHeight
let str= "A,B,C,E,F,G,H,J,K,L,M,N,P,Q,R,S,T,W,X,Y,Z,1,2,3,4,5,6,7,8,9,0,q,w,e,r,t,y,u,i,o,p,a,s,d,f,g,h,j,k,l,z,x,c,v,b,n,m" ;
let astr=str.split( ',' ); //分割字符串形成数组
let sLength=astr.length; //数组长度
for (let i = 0; i <= 3; i++) {
let j=Math.floor(Math.random()*sLength); //随机索引
let deg=Math.random()*30*Math.PI/180; //0-30随机弧度
let text=astr[j]; //随机字符
show_num[i]=text //验证码字符数组
let x=10+i*20 //x坐标
let y=20+Math.random()*8 //y坐标
//位移 旋转角度 颜色 文字 样式开始位置
context.font= 'bold 23px 微软雅黑'
context.translate(x, y);
context.rotate(deg);
context.fillStyle = randomColor();
context.fillText(text,0,0)
context.rotate(-deg)
context.translate(-x,-y)
}
//验证码显示小点
for (let i=0;i<=30;i++){
context.strokeStyle=randomColor() //设置随机色用小点的颜色
context.beginPath(); //开始一条路径
let m=Math.random()*canvas_clientWidth;
let n=Math.random()*canvas_clientHeight;
context.moveTo(m,n) //移动
context.lineTo(m + 1, n + 1); //添加一个新点,然后在画布中创建从该点到最后指定点的线条
context.stroke(); //画上面定义好的路径
}
//验证码显示线条
for (let i = 0; i < 8; i++) {
context.strokeStyle=randomColor()
context.beginPath()
context.moveTo(Math.random()*canvas_clientWidth,Math.random()*canvas_clientHeight);
context.lineTo(Math.random()*canvas_clientWidth,Math.random()*canvas_clientHeight)
context.stroke()
}
}
draw(show_num)
console.log(show_num);
canvas.onclick=()=>{
draw(show_num)
console.log(show_num);
}
|
总结
创建canvas画布,利用随机函数,创建随机颜色 。
draw()函数,用于验证码的生成。字符串分隔存入数组
循环遍历生成验证码的个数
给当前字符串一个位移及旋转角度 文字样式等
随机函数生成小点及线段 context.stroke()画好以上定义好的颜色 位移长短的路径,并显示在canvas画布上
点击canvas画布 可重新生成验证码内容
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/SugarXiXixi/article/details/108982868