您的浏览器不支持canvas,请换个浏览器试试~
当前位置:首页 > 日记 > 正文

使用canvas及js简单生成验证码方法

使用canvas及js简单生成验证码方法

在很多时候都需要用到验证码,前端验证码需要知道Html5中的canvas知识点。验证码生成步骤是:

1.生成一张画布canvas

2.生成随机数验证码 

3.在画布中生成干扰线 

4.把验证码文本填充到画布中 

5.点击画布更换验证码

结构与样式:

<canvas id="mycanvas" width='90' height='40'> 您的浏览器不支持canvas,请换个浏览器试试~</canvas><style>#mycanvas{ cursor: pointer;}</style>

下面来编写js代码:

/*生成4位随机数*/ function rand(){  var str="abcdefghijklmnopqrstuvwxyz0123456789";  var arr=str.split("");  var validate="";  var ranNum;  for(var i=0;i<4;i++){   ranNum=Math.floor(Math.random()*36); //随机数在[0,35]之间   validate+=arr[ranNum];  }  return validate; } /*干扰线的随机x坐标值*/ function lineX(){  var ranLineX=Math.floor(Math.random()*90);  return ranLineX; } /*干扰线的随机y坐标值*/ function lineY(){  var ranLineY=Math.floor(Math.random()*40);  return ranLineY; } function clickChange(){  var mycanvas=document.getElementById('mycanvas');  var cxt=mycanvas.getContext('2d');  cxt.fillStyle='#000';  cxt.fillRect(0,0,90,40);  /*生成干扰线20条*/  for(var j=0;j<20;j++){   cxt.strokeStyle='#fff';   cxt.beginPath(); //若省略beginPath,则每点击一次验证码会累积干扰线的条数   cxt.moveTo(lineX(),lineY());   cxt.lineTo(lineX(),lineY());   cxt.lineWidth=0.5;   cxt.closePath();   cxt.stroke();  }  cxt.fillStyle='red';  cxt.font='bold 20px Arial';  cxt.fillText(rand(),25,25); //把rand()生成的随机数文本填充到canvas中   } clickChange(); /*点击验证码更换*/ mycanvas.onclick=function(e){  e.preventDefault(); //阻止鼠标点击发生默认的行为  clickChange(); };

这样就写好一个较普通的验证码了,当然也有很多需要优化的地方,比如干扰线的随机颜色、可以加干扰点以及文本的随机位置随机颜色等等。赶紧去试试吧~

相关文章

正则表达式字符类加深理解

正则表达式字符类加深理解

字符,正则表达式,电脑软件,正则表达式字符类加深理解:一.基本概念:字符类相对来说是比较简单的,但是也有可能由于理解不够深入或者大意造成一些误区,下面再来做一下介绍。字符类[]能够匹配包含在中括号中的一系列字符中的任意一个,但是匹配的…

Excel表格制作中如何隐藏函数

Excel表格制作中如何隐藏函数

函数,表格,电脑软件,Excel,  在一般的Excel使用中的公式或者函数,是完全能够让浏览者看到的。那么如果有办法将Excel中的公式或函数隐藏起来,只显示运算结果,这样会比较好。以下是小编为您带来的关于Excel隐藏函数,希望对您有所帮助。Excel隐…

Photoshop利用滤镜制作彩色拉丝效

Photoshop利用滤镜制作彩色拉丝效

滤镜,彩色,效果,电脑软件,Photoshop,今天为大家分享Photoshop制作彩色拉丝效果方法,操作很简单的,喜欢的朋友可以参考本文,来看看吧!1、在ps软件中,新建一个800*800的文档,填充黑色,然后在滤镜中添加镜头光晕,如图所示2、再次在滤镜中添加镜头光晕,…

JavaScript数组push方法使用注意事

JavaScript数组push方法使用注意事

方法,数组,注意事项,电脑软件,JavaScript,js 数组的push方法,想必大家都知道是向数组末尾添加元素,但是有一个很关键的点需注意:引自 MDN返回值当调用该方法时,新的 length 属性值将被返回。var sports = ["soccer", "baseball"];var total…

word设置纸张大小的两种方法

word设置纸张大小的两种方法

方法,设置,纸张,大小,两种,  办公经常学要调节纸张大小,虽然常用,但偶尔还是会忘记如何调整纸张大小的方法,那么下面就由小编给大家分享下word设置纸张大小的技巧,希望能帮助到您。word设置纸张大小方法一步骤一:打开word软件,点击桌面快捷图标…

Visual Studio 2017正式版发布 Mac

Visual Studio 2017正式版发布 Mac

新功能,正式版,特性,有哪些,电脑软件, 期待已久的由微软推出的软件开发工具Visual Studio 2017正式版马上要推出了,而Visual Studio 2017 正式版发布时间和Mac版新特性有哪些呢?让我们见证一下Visual Studio 20周年纪念的倾情推荐吧。…

JavaScript基础之this详解

JavaScript基础之this详解

详解,基础,电脑软件,JavaScript,JavaScript的this和Java等面向对象语言中的this大不一样,bind()、call()和apply()函数更是将this的灵活度进一步延伸。为了保证可读性,本文采用意译而非直译。另外,本文版权归原作者所有,翻译仅用于学习。如果对…

excel2010背景大小如何调整

excel2010背景大小如何调整

调整,教程,方法,显示,设置,  在excel中插图背景图片的时候,往往会因为图片太大或太小不合我们心意,要如何才能够调整过来呢。下面让小编为你带来excel2010设置背景大小的方法,希望对你有帮助!excel背景大小的设置方法方法一、直接缩小图像在e…

AI结合c4d设计三维立体文字和图案

AI结合c4d设计三维立体文字和图案

详细教程,文字,图案,三维立体,电脑软件,ai和c4d怎么将平面的文字快速转换成3维的立体效果呢?下面我们就来看看详细的教程,很简单,感兴趣的朋友可以进来参考一下。软件名称:Adobe Illustrator CS6 (AI cs6) 精简绿色中文版(32位+64位)软件大小:20…

基于javascript中的typeof和类型判

基于javascript中的typeof和类型判

类型,详解,电脑软件,javascript,typeof,typeofECMAScript 有 5 种原始类型(primitive type),即 Undefined、Null、Boolean、Number 和 String。我们都知道可以使用typeof运算符求得一个变量的类型,但是对引用类型变量却只会返回object,也就是说t…

CorelDRAW2017怎么正确安装?

CorelDRAW2017怎么正确安装?

安装,正确,电脑软件,4月12日,CorelDRAW迎来了它的新版本--CorelDRAW Graphics Suite 2017。CorelDRAW 2017 的推出让最好的产品变得更好了,它是我们迄今最具创意的最新图形设计程序!作为一个强大的绘图软件,CorelDRAW 2017一经发布便吸引了众多…

ps怎么设计绚丽的彩色背景条效果图

ps怎么设计绚丽的彩色背景条效果图

效果图,绚丽,彩色,背景,电脑软件,ps中想要做一个彩色的斜条纹作为背景,该怎么设计呢?下面我们就来看看详细的教程。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-041、新建ps文件2、执行滤镜>渲染>云彩,效…

软件日记