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


Posted in HTML / CSS onJanuary 02, 2018

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

验证码一般用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基础之图形验证码的示例

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

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

HTML / CSS 相关文章推荐
button在IE6/7下的黑边去除方案
Dec 24 HTML / CSS
CSS3的颜色渐变效果的示例代码
Sep 29 HTML / CSS
CSS3实现王者匹配时的粒子动画效果
Apr 12 HTML / CSS
HTML5网页录音和上传到服务器支持PC、Android,支持IOS微信功能
Apr 26 HTML / CSS
HTML5之SVG 2D入门1—SVG(可缩放矢量图形)概述
Jan 30 HTML / CSS
html5使用canvas实现跟随光标跳动的火焰效果
Jan 07 HTML / CSS
HTML5注册页面示例代码
Mar 27 HTML / CSS
HTML5新特性之语义化标签
Oct 31 HTML / CSS
Canvas环形饼图与手势控制的实现代码
Nov 08 HTML / CSS
HTML5跳转小程序wx-open-launch-weapp的示例代码
Jul 16 HTML / CSS
如何在Canvas上的图形/图像绑定事件监听的实现
Sep 16 HTML / CSS
在CSS中映射鼠标位置并实现通过鼠标移动控制页面元素效果(实例代码)
Apr 22 HTML / CSS
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
Jan 03 #HTML / CSS
html5 canvas绘制放射性渐变色效果
Jan 04 #HTML / CSS
html5中如何将图片的绝对路径转换成文件对象
Jan 11 #HTML / CSS
详解Html5原生拖拽操作
Jan 12 #HTML / CSS
使用Html5、CSS实现文字阴影效果
Jan 17 #HTML / CSS
canvas烟花特效锦集
Jan 17 #HTML / CSS
使用html2canvas实现浏览器截图的示例代码
Jan 26 #HTML / CSS
You might like
JS中encodeURIComponent函数用php解码的代码
2012/03/01 PHP
JavaScript 异步调用框架 (Part 1 - 问题 &amp; 场景)
2009/08/03 Javascript
JavaScript类和继承 this属性使用说明
2010/09/03 Javascript
JavaScript自执行闭包的小例子
2013/06/29 Javascript
JS获取月的最后一天与JS得到一个月份最大天数的实例代码
2013/12/16 Javascript
不提示直接关闭网页窗口的JS示例代码
2013/12/17 Javascript
jQuery实现的漂亮表单效果代码
2015/08/18 Javascript
javascript 动态样式添加的简单实现
2016/10/11 Javascript
Vue结合SignalR实现前后端实时消息同步
2017/09/19 Javascript
vue使用监听实现全选反选功能
2018/07/06 Javascript
vue  directive定义全局和局部指令及指令简写
2018/11/20 Javascript
AJAX在JQuery中的应用详解
2019/01/30 jQuery
谈谈为什么你的 JavaScript 代码如此冗长
2019/01/30 Javascript
Vue filter 过滤当前时间 实现实时更新效果
2019/12/20 Javascript
three.js着色器材质的内置变量示例详解
2020/08/16 Javascript
vue添加自定义右键菜单的完整实例
2020/12/08 Vue.js
Python玩转Excel的读写改实例
2019/02/22 Python
python中多个装饰器的调用顺序详解
2019/07/16 Python
Python OpenCV实现鼠标画框效果
2020/08/19 Python
python中enumerate() 与zip()函数的使用比较实例分析
2019/09/03 Python
详解Python3迁移接口变化采坑记
2019/10/11 Python
Python原始套接字编程实例解析
2020/01/29 Python
使用scrapy ImagesPipeline爬取图片资源的示例代码
2020/09/28 Python
Nike英国官网:Nike.com (UK)
2017/02/13 全球购物
eBay法国购物网站:eBay.fr
2017/10/21 全球购物
西班牙自行车和跑步商店:Alltricks
2018/07/07 全球购物
活动志愿者自荐信
2014/01/27 职场文书
高校教师岗位职责
2014/03/18 职场文书
优秀食品类广告词
2014/03/19 职场文书
管理标语大全
2014/06/24 职场文书
三月学雷锋活动总结
2014/06/26 职场文书
2014员工聘用协议书(最新版)
2014/11/24 职场文书
给上级领导的感谢信
2015/01/22 职场文书
《现实主义勇者的王国再建记》第三弹OST全曲试听片段公开
2022/04/04 日漫
vue elementUI表格控制对应列
2022/04/13 Vue.js
SQL中去除重复数据的几种方法汇总(窗口函数对数据去重)
2023/05/08 MySQL