• 联盟
  • 文章
  • 当前位置:排行榜 > 资讯 > 经验学堂 > 列表经验学堂

    JS生成随机验证码的具体代码

    编辑:996评测网 发布时间:2020-03-02 17:24 分类:经验学堂

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

    在网站中我们很常见到形形色色的验证码,今天我们来用JS来生成一个随机的二维码。
    我们需要用到canvas来进行验证码的绘制
    什么是Canvas
    HTML5 的 canvas 元素使用 Javascript 在网页上绘制图像。
    画布是一个矩形区域,您可以控制其每一像素。
    canvas 拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。
    思路
    我们要做的二维码首先要有随机的数字,其次就是要有随机的位置。
    HTML
    1
    2
    <canvas id="canvas" style="border: 1px solid red; width: 80px; height: 40px;">
    </canvas>
    JS
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    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()函数代码如下,可以随机生成十六进制颜色码。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    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来确定随机数范围。代码如下:
    1
    2
    3
    function getRandomNum(n){
    return parseInt(Math.random() * n);
    }
    完整代码:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    <!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>
    以上就是本文JS生成随机验证码的具体代码的全部内容
    (责任编辑:996top广告联盟评测)
    上一篇:pdf转jpg怎么转换有软件工具吗? 下一篇:python操作数据库将前端传回来的用户名和密码写入表中?
    下级栏目
    最新加入
  • 12021-01-31团成移动联盟
  • 22021-01-31CPS日结广告联盟
  • 32020-07-15发发广告联盟
  • 42020-06-22蜜趣CPS联盟
  • 52020-05-05趣米移动广告
  • 62020-04-28斯巴达联盟
  • 72020-04-28萌新移动联盟
  • 82020-04-22八通广告联盟
  • 92020-04-19998广告联盟
  • 102020-04-15誉见广告平台
  • 热评联盟
  • 1点评[93]铁憨憨广告联盟
  • 2点评[32]非凡广告联盟
  • 3点评[25]誉见广告平台
  • 4点评[22]辉耀移动联盟
  • 5点评[19]巨梦广告联盟
  • 6点评[16]望云广告联盟
  • 7点评[13]快唯广告联盟
  • 8点评[12]晨阳广告传媒
  • 9点评[10]盖亚联盟CPA
  • 10点评[10]亿云联盟
  • 服务排行
    人气排行
  • 1浏览[419]盖亚联盟CPA
  • 2浏览[272]趣米移动广告
  • 3浏览[265]青瓜传媒APP推广
  • 4浏览[218]小明精准联盟
  • 5浏览[216]百度联盟
  • 6浏览[185]CPA唯尚广告联盟
  • 7浏览[154]非凡广告联盟
  • 8浏览[124]易盟广告
  • 9浏览[121]联合云享广告平台
  • 10浏览[116]超越广告联盟
  • 关于996| 版权声明| 联系方式| 广告服务

    Copyright © 版权所有:996评测网 广告联系QQ:2521646590 (请注明:投广告)
    (评论内容只代表网友观点,与996评测网立场无关)