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 相关文章推荐
刷新时清空文本框内容的js代码
Apr 23 Javascript
javascript new后的constructor属性
Aug 05 Javascript
AngularJS ui-router (嵌套路由)实例
Mar 10 Javascript
layui分页效果实现代码
May 19 Javascript
Vue导出json数据到Excel电子表格的示例
Dec 04 Javascript
微信小程序checkbox组件使用详解
Jan 31 Javascript
vue2.0使用v-for循环制作多级嵌套菜单栏
Jun 25 Javascript
详解React项目如何修改打包地址(编译输出文件地址)
Mar 21 Javascript
react+redux仿微信聊天界面
Jun 21 Javascript
ionic+html5+API实现双击返回键退出应用
Sep 17 Javascript
在Vue.js中使用TypeScript的方法
Mar 19 Javascript
openlayers实现地图测距测面
Sep 25 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
基于mysql的bbs设计(三)
2006/10/09 PHP
PHP array_flip() 删除重复数组元素专用函数
2010/05/16 PHP
php curl模拟post请求小实例
2013/11/13 PHP
我整理的PHP 7.0主要新特性
2016/01/07 PHP
PHP使用curl模拟post上传及接收文件的方法
2016/03/04 PHP
php 时间time与日期date之间的使用详解及区别
2016/11/07 PHP
laravel 输出最后执行sql 附:whereIn的使用方法
2019/10/10 PHP
js window.onload 加载多个函数的方法
2009/11/02 Javascript
javascript中字符串替换函数replace()方法与c# 、vb 替换有一点不同
2010/06/25 Javascript
js精美的幻灯片画集特效代码分享
2015/08/29 Javascript
Node.js测试中的Mock文件系统详解
2016/11/21 Javascript
JS正则表达式验证密码格式的集中情况总结
2017/02/23 Javascript
利用js的闭包原理做对象封装及调用方法
2017/04/07 Javascript
JS库之ParticlesJS使用简介
2017/09/12 Javascript
在vue项目中使用element-ui的Upload上传组件的示例
2018/02/08 Javascript
解决vue中使用swiper插件问题及swiper在vue中的用法
2018/04/04 Javascript
Django+Vue跨域环境配置详解
2018/07/06 Javascript
Vue.js如何使用Socket.IO的示例代码
2019/09/05 Javascript
小程序自定义弹框效果
2020/11/16 Javascript
[00:50]2014DOTA2国际邀请赛 NEWBEE战队回顾
2014/08/01 DOTA
python 实现上传图片并预览的3种方法(推荐)
2017/07/14 Python
Python xlwt设置excel单元格字体及格式
2020/04/18 Python
ActiveMQ:使用Python访问ActiveMQ的方法
2019/01/30 Python
python实现简单银行管理系统
2019/10/25 Python
python使用rsa非对称加密过程解析
2019/12/28 Python
使用Tensorflow实现可视化中间层和卷积层
2020/01/24 Python
Python使用ElementTree美化XML格式的操作
2020/03/06 Python
Tensorflow中的图(tf.Graph)和会话(tf.Session)的实现
2020/04/22 Python
如何理解Python中包的引入
2020/05/29 Python
Python 如何调试程序崩溃错误
2020/08/03 Python
现代家居用品及礼品:LBC Modern
2018/06/24 全球购物
充分就业社区汇报材料
2014/05/07 职场文书
个性车贴标语
2014/06/24 职场文书
党员自评材料范文
2014/12/17 职场文书
《女娲补天》教学反思
2016/02/20 职场文书
2016年公共机构节能宣传周活动总结
2016/04/05 职场文书