JS如何生成随机验证码


Posted in Javascript onMarch 02, 2020

本文实例为大家分享了JS生成随机验证码的具体代码,供大家参考,具体内容如下

JS如何生成随机验证码

在网站中我们很常见到形形色色的验证码,今天我们来用JS来生成一个随机的二维码。

我们需要用到canvas来进行验证码的绘制

什么是Canvas

HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像。
画布是一个矩形区域,您可以控制其每一像素。
canvas 拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

思路

我们要做的二维码首先要有随机的数字,其次就是要有随机的位置。

HTML

<canvas id="canvas" style="border: 1px solid red; width: 80px; height: 40px;">
</canvas>

JS

function getVerification() { //二维码
 var ctx = document.getElementById("canvas").getContext("2d");
 // 清空画布
 ctx.clearRect(0,0, 400, 400);
 // 设置字体
 ctx.font = "128px bold 黑体";
 // 设置垂直对齐方式
 ctx.textBaseline = "top";
 // 设置颜色
 ctx.fillStyle = randomColor();
 // 绘制文字(参数:要写的字,x坐标,y坐标)
 ctx.fillText(getRandomNum(10), 0, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 50, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 100, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 150, getRandomNum(50));
}

我们使用ctx.fillStyle = randomColor();来设置随机的颜色,每写一个数字换一个颜色,randomColoe()函数代码如下,可以随机生成十六进制颜色码。

function randomColor() {
 var colorValue = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f";
 var colorArray = colorValue.split(",");
 var color = "#";
 for (var i = 0; i < 6; i++) {
 color += colorArray[Math.floor(Math.random() * 16)];
 }
 return color;
}

我们使用getRandomNum()来获取随机显示的数字和随机每次字体的y轴方向的位置。验证码的每个数字分别进行获取。传入的参数n来确定随机数范围。代码如下:

function getRandomNum(n){
 return parseInt(Math.random() * n); 
}

完整代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>2</title>
</head>

<body>
 <canvas id="canvas" style="border: 1px solid red; width: 80px; height: 40px;"></canvas>
 <span id="yanzhengma"></span><button onclick="getVerification()">看不清</button>
 <script>
 function randomColor() {
 var colorValue = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f";
 var colorArray = colorValue.split(",");
 var color = "#";
 for (var i = 0; i < 6; i++) {
 color += colorArray[Math.floor(Math.random() * 16)];
 }
 return color;
 }
 function getRandomNum(n){
 return parseInt(Math.random() * n); 
 }
 function getVerification() {
 var ctx = document.getElementById("canvas").getContext("2d");
 ctx.clearRect(0,0, 400, 400);
 // 设置字体
 ctx.font = "128px bold 黑体";
 // 设置垂直对齐方式
 ctx.textBaseline = "top";
 // 设置颜色
 ctx.fillStyle = randomColor();
 // 绘制文字(参数:要写的字,x坐标,y坐标)
 ctx.fillText(getRandomNum(10), 0, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 50, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 100, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 150, getRandomNum(50));
 }
 getVerification();
 </script>
</body>
</html>

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

Javascript 相关文章推荐
Javascript 判断函数类型完美解决方案
Sep 02 Javascript
一个可绑定数据源的jQuery数据表格插件
Jul 17 Javascript
javascript根据像素点取位置示例
Jan 27 Javascript
javascript的解析执行顺序在各个浏览器中的不同
Mar 17 Javascript
javascript实例分享---具有立体效果的图片特效
Jun 08 Javascript
理解JavaScript事件对象
Jan 25 Javascript
javascript循环链表之约瑟夫环的实现方法
Jan 16 Javascript
jQuery事件与动画基础详解
Feb 23 Javascript
简单实现AngularJS轮播图效果
Apr 10 Javascript
Node.js搭建小程序后台服务
Jan 03 Javascript
基于Vue实现拖拽效果
Apr 27 Javascript
Vue的transition-group与Virtual Dom Diff算法的使用
Dec 09 Javascript
js实现烟花特效
Mar 02 #Javascript
ES6使用 Array.includes 处理多重条件用法实例分析
Mar 02 #Javascript
JS造成内存泄漏的几种情况实例分析
Mar 02 #Javascript
JavaScript HTML DOM 元素 (节点)新增,编辑,删除操作实例分析
Mar 02 #Javascript
JavaScript中break、continue和return的用法区别实例分析
Mar 02 #Javascript
Vue Router的手写实现方法实现
Mar 02 #Javascript
ES6中Set和Map用法实例详解
Mar 02 #Javascript
You might like
定制404错误页面,并发信给管理员的程序
2006/10/09 PHP
比较好用的PHP防注入漏洞过滤函数代码
2012/04/11 PHP
PHP flush()与ob_flush()的区别详解
2013/06/03 PHP
php实现mysql封装类示例
2014/05/07 PHP
php htmlentities()函数的定义和用法
2016/05/13 PHP
php封装的验证码工具类完整实例
2016/10/19 PHP
Jquery 的扩展方法总结
2011/10/01 Javascript
js 自定义个性下拉选择框示例
2013/08/20 Javascript
jQuery:delegate中select()不起作用的解决方法(实例讲解)
2014/01/26 Javascript
使用jQuery判断Div是否在可视区域的方法 判断div是否可见
2016/02/17 Javascript
下雪了 javascript实现雪花飞舞
2020/08/02 Javascript
JS集成fckeditor及判断内容是否为空的方法
2016/05/27 Javascript
Knockoutjs 学习系列(一)ko初体验
2016/06/07 Javascript
jQuery中的select操作详解
2016/11/29 Javascript
详解JS: reduce方法实现 webpack多文件入口
2017/02/14 Javascript
javascript编程实现栈的方法详解【经典数据结构】
2017/04/11 Javascript
浅谈 Vue 项目优化的方法
2017/12/16 Javascript
微信小程序上传图片实例
2018/05/28 Javascript
JavaScript实现滑块验证解锁
2021/01/07 Javascript
[41:12]Liquid vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.24
2019/09/10 DOTA
Python获取脚本所在目录的正确方法
2014/04/15 Python
PYTHON压平嵌套列表的简单实现
2016/06/08 Python
Python实现的递归神经网络简单示例
2017/08/11 Python
python实现在IDLE中输入多行的方法
2018/04/19 Python
Python实现使用request模块下载图片demo示例
2019/05/24 Python
基于python读取.mat文件并取出信息
2019/12/16 Python
使用Python将图片转正方形的两种方法实例代码详解
2020/04/29 Python
商务英语专业毕业生自荐信
2013/11/05 职场文书
倡议书的写法
2014/08/30 职场文书
设备收款委托书范本
2014/10/02 职场文书
个人学习群众路线心得体会
2014/11/05 职场文书
合理化建议书
2015/02/04 职场文书
风雨哈佛路观后感
2015/06/03 职场文书
MySQL复制问题的三个参数分析
2021/04/07 MySQL
Promise面试题详解之控制并发
2021/05/14 面试题
Java8 CompletableFuture 异步回调
2022/04/28 Java/Android