本文实例为大家分享了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="/UploadFiles/2021-04-02/">#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()*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画布 可重新生成验证码内容
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 魔兽世界wlk恶魔术士一键输出宏是什么 wlk恶魔术士一键输出宏介绍
- 医学爱好者狂喜:UP主把医学史做成了格斗游戏!
- PS5 Pro评分解禁!准备升级入手吗?
- 我们盘点了近期火热的国产单机游戏!《琉隐神渡》等 你期待哪款?
- 2019年第12届广州影音展双碟纪念版ADMS2CD[MP3/WAV]
- 黄安《救姻缘》台首版[WAV+CUE]
- 模拟之声慢刻CD《柏林之声4》[正版CD低速原抓WAV+CUE]
- 李宗盛 《李宗盛经典金曲》[WAV+CUE][1G]
- 周华健《粤语精选》[WAV+CUE][1G]
- 蔡婧2024《天空》HQCDII头版限量编号[WAV+CUE][1G]
- 陈奂仁.2011-谁是陈奂仁【BBS】【FLAC分轨】
- 群星.2024-幻乐森林影视原声带【韶愔音乐】【FLAC分轨】
- 黎明.1999-向往金色的黎明新歌+精选2CD【环球】【WAV+CUE】
- 发烧女声Méav《美芙的祈祷》发烧女声 [WAV+CUE][820M]
- 雷婷 《我的爱回不来》紫银合金AQCD [WAV+CUE][1G]