代码之家(www.adminjie.com)精品网站源码,微信源码,游戏源码分享平台。《交流群:1037940574》
当前位置:网站首页 技术文章 网页制作 正文

js+h5 canvas实现图片验证码

时间:2020-10-18 [网页制作]作者:adminjie 浏览:42 次

font-family: "Source Sans Pro", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; background-color: rgb(255, 255, 255);">本文实例为大家分享了js+h5 canvas实现图片验证码的具体代码,供大家参考,具体内容如下

实现效果
js+h5 canvas实现图片验证码

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="js+h5 canvas实现图片验证码" title="看不清?单击此处刷新" class="login_code_img" > -->
</div>

canvas{

width: 130px;
height: 45px;
display: inline-block;
border: 1px solid #c9c9c9;
border-radius: 5px;
}
2.js

代码如下(示例):

//验证码生成
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()30Math.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画布 可重新生成验证码内容

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。


转载请注明来源:js+h5 canvas实现图片验证码

本文永久链接地址:https://www.adminjie.com/post/4080.html

免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:点此维权 站长会进行审查之后,情况属实的会在三个工作日内为您删除。

  • 代码之家会员升级
  • 最新文章
  • 阿里云大优惠
  • 热门文章