• 使用canvas及js简单生成验证码方法


    在很多时候都需要用到验证码,前端验证码需要知道Html5中的canvas知识点。验证码生成步骤是:1.生成一张画布canvas 2.生成随机数验证码  3.在画布中生成干扰线  4.把验证码文本填充到画布中  5.点击画布更换验证码

    结构与样式:

    <canvas id="mycanvas" width='90' height='40'>
        您的浏览器不支持canvas,请换个浏览器试试~
    </canvas>
    
    <style>
    #mycanvas{
        cursor: pointer;
    }
    </style>
    

    下面来编写js代码:

        /*生成4位随机数*/
        function rand(){
            var str="abcdefghijklmnopqrstuvwxyz0123456789";
            var arr=str.split("");
            var validate="";
            var ranNum;
            for(var i=0;i<4;i++){
                ranNum=Math.floor(Math.random()*36);   //随机数在[0,35]之间
                validate+=arr[ranNum];
            }
            return validate;
        }
    
        /*干扰线的随机x坐标值*/
        function lineX(){
            var ranLineX=Math.floor(Math.random()*90);
            return ranLineX;
        }
    
        /*干扰线的随机y坐标值*/
        function lineY(){
            var ranLineY=Math.floor(Math.random()*40);
            return ranLineY;
        }
    
        function clickChange(){
            var mycanvas=document.getElementById('mycanvas');
            var cxt=mycanvas.getContext('2d');
            cxt.fillStyle='#000';
            cxt.fillRect(0,0,90,40);
            
            /*生成干扰线20条*/
            for(var j=0;j<20;j++){
                cxt.strokeStyle='#fff';
                cxt.beginPath();    //若省略beginPath,则每点击一次验证码会累积干扰线的条数
                cxt.moveTo(lineX(),lineY());
                cxt.lineTo(lineX(),lineY());
                cxt.lineWidth=0.5;
                cxt.closePath();
                cxt.stroke();
            }
    
            cxt.fillStyle='red';
            cxt.font='bold 20px Arial';
            cxt.fillText(rand(),25,25);   //把rand()生成的随机数文本填充到canvas中      
        }
     
        clickChange();
    
        /*点击验证码更换*/
        mycanvas.onclick=function(e){
            e.preventDefault();   //阻止鼠标点击发生默认的行为
            clickChange();
        };

    这样就写好一个较普通的验证码了,当然也有很多需要优化的地方,比如干扰线的随机颜色、可以加干扰点以及文本的随机位置随机颜色等等。赶紧去试试吧~

  • 相关阅读:
    第一章:Android系统的编译和移植实例读书笔记
    第二章:Android系统与嵌入式开发读书笔记
    第三章:Android移植平台工具介绍读书笔记
    第十章 嵌入式Linux的调试技术
    第九章 硬件抽象层:HAL
    第八章 让开发板发出声音:蜂鸣器驱动
    第七章 LED将为我闪烁:控制发光二极管
    第六章 第一个Linux驱动程序:统计单词个数
    第五章 搭建S3C6410开发板的测试环境
    第四章 源代码的下载和编译
  • 原文地址:https://www.cnblogs.com/heyujun-/p/6658549.html
Copyright © 2020-2023  润新知