JavaScript生成随机验证码代码实例


Posted in Javascript onSeptember 28, 2019

利用canvas制作一个随机验证码:

1、clearRect:context.clearRect(x,y,width,height);清空给定矩形内的指定像素

2、fillStyle:设置画笔的颜色

3、rotate(deg):旋转角度,以弧度旋转(弧度=degrees*Math.PI/180 )

4、translate(): 方法重新映射画布上的位置

5、Math.random():获取0-1之间的一个随机数,不包含1

JavaScript生成随机验证码代码实例

<!-- HTML -->
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>canvas随机验证码</title>
  </head>
  <body>
    <canvas id="canvas" width="100" height="40" style="border: 1px solid red;display: block;margin: 0 auto;"></canvas>
  </body>
  <script type="text/javascript">
    var myCanvas = document.querySelector("#canvas");
    var blur = myCanvas.getContext("2d");
    // 当点击画布时创建一个新的路径
    // 验证码封装
    myCanvas.onclick = function() {
      // 实现点击画布创建一个新的验证码
      blur.clearRect(0,0,100,40);
      verify();
    }
    verify();
    function verify() {
      // 绘制矩形框
      // blur.strokeRect(0,0,100,40);
      // 随机验证码
      var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "s", "t", "u",
        "v", "w", "x", "y", "z", "A", "B", "C", "D", "F", "G", "H", "I", "J", "K", "L", "S", "T", "U", "V", "W", "X", "Y",
        "Z"
      ];
      // 显示四位数的验证码
      for (var i = 0; i < 4; i++) {
        var x = 20 + 20 * i;
        var y = 20 + 10 * Math.random();
        // console.log(x,y);
        // 在数组中获取到随机的索引整数
        var index = Math.floor(Math.random() * arr.length);
        // 通过随机的索引获取到随机的元素
        var texts = arr[index];
        // 设置验证码的相关样式
        blur.font = "bold 20px 微软雅黑";
        blur.fillStyle = textColor();
        // 画布旋转显示
        // translate() 方法重新映射画布上的位置
        blur.translate(x, y);
        // 将画布旋转,旋转角度,以弧度旋转(弧度=degrees*Math.PI/180 )
        var deg = 90 * Math.random() * Math.PI / 180;
        blur.rotate(deg); //
        blur.fillText(texts, 0, 0);
        // 将画布映射返回原来的位置
        blur.rotate(-deg);
        blur.translate(-x, -y);
      }
      
      // 制作验证码的干扰线制作
      for(var i=0;i<6;i++){
        blur.beginPath();
        blur.moveTo(Math.random()*100,Math.random()*40);
        blur.lineTo(Math.random()*100,Math.random()*40);
        // 设置干扰线的颜色
        blur.strokeStyle=textColor();
        blur.stroke();
      }
      // 制作验证码的干扰圆点
      for(var i=0;i<20;i++){
        blur.beginPath();
        var x=Math.random()*100;
        var y=Math.random()*100;
        blur.moveTo(x,y);
        blur.lineTo(x+1,y+1);
        // 设置干扰线的颜色
        blur.strokeStyle=textColor();
        blur.stroke();
      }
    }
    // 获取随机颜色封装
    function textColor(){
      var red=Math.floor(Math.random()*256);
      var green=Math.floor(Math.random()*256);
      var blue=Math.floor(Math.random()*256);
      return "rgb("+red+","+green+","+blue+")";
    }
  </script>
</html>

x 要清除的矩形左上角的 x 坐标
y 要清除的矩形左上角的 y 坐标
width 要清除的矩形的宽度,以像素计
height 要清除的矩形的高度,以像素计

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

Javascript 相关文章推荐
jquery中选择块并改变属性值的方法
Jul 31 Javascript
js 动态为textbox添加下拉框数据源的方法
Apr 24 Javascript
Javascript中arguments和arguments.callee的区别浅析
Apr 24 Javascript
JS基于FileSystemObject创建一个指定路径的TXT文本文件
Aug 05 Javascript
JavaScript+html5 canvas绘制渐变区域完整实例
Jan 26 Javascript
详解Node.js:events事件模块
Nov 24 Javascript
js实现会跳动的日历效果(完整实例)
Oct 18 Javascript
Angular2实现组件交互的方法分析
Dec 19 Javascript
JS实现的雪花飘落特效示例
Dec 03 Javascript
基于Vue实现微前端的示例代码
Apr 24 Javascript
JS 设计模式之:工厂模式定义与实现方法浅析
May 06 Javascript
javascript实现贪吃蛇游戏(娱乐版)
Aug 17 Javascript
laydate只显示时分 不显示秒的功能实现方法
Sep 28 #Javascript
layui时间控件选择时间范围的实现方法
Sep 28 #Javascript
layui table 表格上添加日期控件的两种方法
Sep 28 #Javascript
Layui选项卡制作历史浏览记录的方法
Sep 28 #Javascript
Layui带搜索的下拉框的使用以及动态数据绑定方法
Sep 28 #Javascript
layui的select联动实现代码
Sep 28 #Javascript
关于layui的下拉搜索框异步加载数据的解决方法
Sep 28 #Javascript
You might like
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
2012/06/17 PHP
WordPress导航菜单的滚动和淡入淡出效果的实现要点
2015/12/14 PHP
Yii2框架RESTful API 格式化响应,授权认证和速率限制三部分详解
2016/11/10 PHP
JSQL 批量图片切换的实现代码
2010/05/05 Javascript
Js获取事件对象代码
2010/08/05 Javascript
在IE和VB中支持png图片透明效果的实现方法(vb源码打包)
2011/04/01 Javascript
基于jquery的仿百度搜索框效果代码
2011/04/11 Javascript
Javascript将数值转换为金额格式(分隔千分位和自动增加小数点)
2016/06/22 Javascript
微信小程序 连续旋转动画(this.animation.rotate)详解
2017/04/07 Javascript
Jquery EasyUI $.Parser
2017/06/02 jQuery
Angularjs按需查询实例代码
2017/10/30 Javascript
vue cli构建的项目中请求代理与项目打包问题
2018/02/26 Javascript
vue中使用element-ui进行表单验证的实例代码
2018/06/22 Javascript
mpvue将vue项目转换为小程序
2018/09/30 Javascript
JS闭包经典实例详解
2018/12/20 Javascript
js实现适配移动端的拖动效果
2020/01/13 Javascript
跟老齐学Python之Python文档
2014/10/10 Python
Python类的多重继承问题深入分析
2014/11/09 Python
python实现图片变亮或者变暗的方法
2015/06/01 Python
python实现的用于搜索文件并进行内容替换的类实例
2015/06/28 Python
python中urlparse模块介绍与使用示例
2017/11/19 Python
详解Python核心对象类型字符串
2018/02/11 Python
python2.7实现邮件发送功能
2018/12/12 Python
PyCharm2019安装教程及其使用(图文教程)
2019/09/29 Python
python opencv将表格图片按照表格框线分割和识别
2019/10/30 Python
使用pyqt5 tablewidget 单元格设置正则表达式
2019/12/13 Python
美国球迷装备的第一来源:FOCO
2020/07/03 全球购物
The North Face官方旗舰店:美国著名户外品牌
2020/09/28 全球购物
2013年最新自荐信范文
2014/06/23 职场文书
销售代理协议书
2014/09/30 职场文书
2014年保育员工作总结
2014/12/02 职场文书
英语投诉信范文
2015/07/03 职场文书
中秋节感想
2015/08/10 职场文书
企业年会祝酒词
2015/08/11 职场文书
大队委员竞选演讲稿
2015/11/20 职场文书
在python中读取和写入CSV文件详情
2022/06/28 Python