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 相关文章推荐
一款纯css3实现的动画加载导航
Oct 08 HTML / CSS
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
Mar 02 HTML / CSS
详解CSS3中强大的filter(滤镜)属性
Jun 29 HTML / CSS
HTML5 声明兼容IE的写法
May 16 HTML / CSS
html5 的a标签 Href 拨电话的写法
Nov 04 HTML / CSS
基于html5实现的图片墙效果
Oct 16 HTML / CSS
HTML5 Canvas 绘图——使用 Canvas 绘制图形图文教程 使用html5 canvas 绘制精美的图
Aug 31 HTML / CSS
使用phonegap进行提示操作的具体方法
Mar 30 HTML / CSS
将SVG图引入到HTML页面的实现
Sep 20 HTML / CSS
血轮眼轮回眼特效 html+css
Mar 31 HTML / CSS
html form表单基础入门案例讲解
Jul 15 HTML / CSS
CSS 实现角标效果的完整代码
Jun 28 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
自动生成文章摘要的代码[PHP 版本]
2007/03/20 PHP
中国站长站 For Dede4.0 采集规则
2007/05/27 PHP
PHP面向对象程序设计实例分析
2016/01/26 PHP
php删除一个路径下的所有文件夹和文件的方法
2018/02/07 PHP
PHP实现的curl批量请求操作示例
2018/06/06 PHP
Javascript的一种模块模式
2008/03/22 Javascript
JavaScript去掉空格的方法集合
2010/12/28 Javascript
jquery下为Event handler传递动态参数的代码
2011/01/06 Javascript
jquery实现图片等比例缩放以及max-width在ie中不兼容解决
2013/03/21 Javascript
原生js实现shift/ctrl/alt按键的获取
2013/04/08 Javascript
jquery 文本上下无缝滚动,鼠标放上去就停止 小例子
2013/06/05 Javascript
技术男用来对妹子表白的百度首页
2014/07/23 Javascript
jQuery中focus事件用法实例
2014/12/26 Javascript
JS实现的文字与图片定时切换效果代码
2015/10/06 Javascript
深入解析JavaScript的闭包机制
2015/10/20 Javascript
18个非常棒的jQuery代码片段
2015/11/02 Javascript
浅谈JavaScript的push(),pop(),concat()方法
2016/06/03 Javascript
BootStrap Validator使用注意事项(必看篇)
2016/09/28 Javascript
vue中路由验证和相应拦截的使用详解
2017/12/13 Javascript
使用nodejs分离html文件里的js和css详解
2019/04/12 NodeJs
浅谈vuex为什么不建议在action中修改state
2020/02/02 Javascript
原生JS实现拖拽效果
2020/12/04 Javascript
django 常用orm操作详解
2017/09/13 Python
python中字符串比较使用is、==和cmp()总结
2018/03/18 Python
Django框架实现的普通登录案例【使用POST方法】
2019/05/15 Python
python opencv将图片转为灰度图的方法示例
2019/07/31 Python
python KNN算法实现鸢尾花数据集分类
2019/10/24 Python
Python:合并两个numpy矩阵的实现
2019/12/02 Python
Keras模型转成tensorflow的.pb操作
2020/07/06 Python
毕业生就业自荐信
2013/12/04 职场文书
食品安全责任书
2014/04/15 职场文书
充分就业社区汇报材料
2014/05/07 职场文书
2015年学校精神文明工作总结
2015/05/27 职场文书
工作表现证明
2015/06/15 职场文书
jquery插件实现悬浮的菜单
2021/04/24 jQuery
MongoDB日志切割的三种方式总结
2021/09/15 MongoDB