• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    canvas基础之图形验证码的示例

    在通常的登录界面我们都可以看到验证码,验证码的作用是检测是不是人在操作,防止机器等非人操作,防止数据库被轻而易举的攻破。

    验证码一般用PHP和java等后端语言编写;

    但是在前端,用canva或者SVG也可以绘制验证码;

    直接上干货:

    <!DOCTYPE html>
    <html>
    
        <head>
            <meta charset="UTF-8">
            <title></title>
            <style type="text/css">
                canvas {
                    border: 1px solid red;
                }
            </style>
        </head>
    
        <body>
            <canvas id="myCanvas" width="100" height="40">
                您的浏览器不支持canvas
            </canvas>
        </body>
        <script type="text/javascript">
            var myCanvas = document.getElementById("myCanvas");
            var context = myCanvas.getContext("2d");
            //随机字符(透明度)(大小随机,位置随机);
            var strStore = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
            //随机函数
            function roundNum(min, max) {
                return parseInt(Math.random() * (max - min) + min);
            }
            //文字内容部分:
            var str = "";
            for(var i = 0; i < 5; i++) {
                context.beginPath();
                //随机颜色(浅色:RGB - 200~250)
                var color = `rgb(${roundNum(0,255)},${roundNum(0,255)},${roundNum(0,255)})`;
                context.fillStyle = color;
                context.font = roundNum(20,30)+"px Arial";
                context.textAlign = "center";
                str = strStore[roundNum(0,strStore.length)];
                context.fillText(str, 10 + 18 * i, roundNum(20,35));
            }
    
            //10个左右的随机(长度随机,位置随机),干扰线
            for(var j = 0; j < roundNum(5, 10); j++) {
                context.beginPath();
                var color = `rgb(${roundNum(0,255)},${roundNum(0,255)},${roundNum(0,255)})`;
                context.strokeStyle = color;
                context.moveTo(roundNum(0, 100), roundNum(0, 40));
                context.lineTo(roundNum(0, 100), roundNum(0, 40));
                context.stroke();
            }
    
            //干扰项:10个左右的随机(半径随机,位置随机),干扰圆
            for(var j = 0; j < roundNum(5, 10); j++) {
                context.beginPath();
                context.fillStyle = color;
                context.arc(roundNum(0, 100), roundNum(0, 40), roundNum(0, 5), Math.PI * 2 / (roundNum(1, 360)), Math.PI * 2 / (roundNum(1, 360)));
                context.fill();
            }
            
        </script>
    
    </html>
    

    结果如图:

    至于要拿来咋用,就看大家高兴了。想怎么整这么整。

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

    上一篇:canvas三角函数模拟水波效果的示例代码
    下一篇:HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    canvas基础之图形验证码的示例 canvas,基础,之,图形,验证,