前端学习笔记<五>——图形验证码

2020.8.20

练习题的两种验证码

第一种

第一种,图形验证码功能没有验证,比如图形显示1234,输入2345也可以成功。

<tr>
	<td class="lab">图片验证码:</td>
    <td>
    <input type="text" name="yzm" placeholder="不区分大小写" class="txt">
    </td>
    <td>
    <div id="code_box">Af3D</div>
    </td>
</tr>
<script>
    var code_box = document.getElementById("code_box");
 
    function refreshCode() {
 		
    	//62个字符 随机选择4位
        var code = '0123456789qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM',
            char = '',
            result = '';
 
        for (var i = 0; i < 4; i++) {
 
            //随机选择一位  (0,61) 写出0到61的随机的索引数字
            var code_index = Math.round(Math.random()*61);
            //得到随机的索引  取出随机地字符
            var char = code[code_index];
            //随机取出的字符 存在几个相同重复的问题 ,而且对于字母,不能区分大小写。
            // 避免重复的思路是:取出字符之后,和最后的result对比一下,看看里边是不是已经存在了,如果存在本次循环就终止,进行下一次
            if (result.toUpperCase().indexOf(char.toUpperCase()) > -1)
            //indexOf() == -1 说明结果里边没有要找的字符 那么 > -1 就是 里边有重复的字符
            {	
            	i --;
                //为什么会 --? 因为如果条件成立,那么本轮循环就结束进行下一轮循环(自然i就加1了),那么本轮本应该取出的字符就没有了
                //到最后会少一个字符 缺席
                continue;//终止本轮循环 进行下一轮
            }
            result += char;
        }
        code_box.innerHTML = result;
    }
    //点击事件
    code_box.onclick = refreshCode;
</script>

在这里插入图片描述

第二种

图片验证码:<input type="text"  id="picture"  value="" >
        <canvas id="canvas" width="100" height="25" οnclick="dj()" 
        style="border: 1px solid #ccc;border-radius: 5px;"></canvas>
<script>
        var show_num = [];
        draw(show_num);
       function dj(){
        draw(show_num);   
        }
       function sublim(){
       var val=document.getElementById("text").value;  
                   var num = show_num.join("");
                   if(val==''){
                       alert('请输入验证码!');
                   }else if(val == num){
                       alert('提交成功!');
                       document.getElementById(".input-val").val('');
                       draw(show_num);
       
                   }else{
                       alert('验证码错误!\n你输入的是:  '+val+"\n正确的是:  "+num+'\n请重新输入!');
                       document.getElementById("text").value='';
                       draw(show_num);
                   }
               
              
               
                 }
       function draw(show_num) {
               var canvas_width=document.getElementById('canvas').clientWidth;
               var canvas_height=document.getElementById('canvas').clientHeight;
               var canvas = document.getElementById("canvas");//获取到canvas的对象,演员
               var context = canvas.getContext("2d");//获取到canvas画图的环境,演员表演的舞台
               canvas.width = canvas_width;
               canvas.height = canvas_height;
               var sCode = "A,B,C,E,F,G,H,J,K,L,M,N,P,Q,R,S,T,W,X,Y,Z,1,2,3,4,5,6,7,8,9,0,q,w,e,r,t,y,u,i,o,p,a,s,d,f,g,h,j,k,l,z,x,c,v,b,n,m";
               var aCode = sCode.split(",");
               var aLength = aCode.length;//获取到数组的长度
                   
               for (var i = 0; i <= 3; i++) {
                   var j = Math.floor(Math.random() * aLength);//获取到随机的索引值
                   var deg = Math.random() * 30 * Math.PI / 180;//产生0~30之间的随机弧度
                   var txt = aCode[j];//得到随机的一个内容
                   show_num[i] = txt;
                   var x = 10 + i * 20;//文字在canvas上的x坐标
                   var y = 20 + Math.random() * 8;//文字在canvas上的y坐标
                   context.font = "bold 23px 微软雅黑";
       
                   context.translate(x, y);
                   context.rotate(deg);
       
                   context.fillStyle = randomColor();
                   context.fillText(txt, 0, 0);
       
                   context.rotate(-deg);
                   context.translate(-x, -y);
               }
               for (var i = 0; i <= 5; i++) { //验证码上显示线条
                   context.strokeStyle = randomColor();
                   context.beginPath();
                   context.moveTo(Math.random() * canvas_width, Math.random() * canvas_height);
                   context.lineTo(Math.random() * canvas_width, Math.random() * canvas_height);
                   context.stroke();
               }
               for (var i = 0; i <= 30; i++) { //验证码上显示小点
                   context.strokeStyle = randomColor();
                   context.beginPath();
                   var x = Math.random() * canvas_width;
                   var y = Math.random() * canvas_height;
                   context.moveTo(x, y);
                   context.lineTo(x + 1, y + 1);
                   context.stroke();
               }
           }
       function randomColor() {//得到随机的颜色值
               var r = Math.floor(Math.random() * 256);
               var g = Math.floor(Math.random() * 256);
               var b = Math.floor(Math.random() * 256);
               return "rgb(" + r + "," + g + "," + b + ")";
           }
</script>

在这里插入图片描述
HTML5 Canvas

<canvas> 标签定义图形,比如图表和其他图像,您必须使用脚本来绘制图形。
在画布上(Canvas)画一个红色矩形,渐变矩形,彩色矩形,和一些彩色的文字。
HTML5 <canvas> 元素用于图形的绘制,通过脚本 (通常是JavaScript)来完成.
<canvas> 标签只是图形容器,您必须使用脚本来绘制图形。
你可以通过多种方法使用 canvas 绘制路径,盒、圆、字符以及添加图像。

单独练习题学习

学习链接:图形验证码的两种实现方式

图形验证码无验证
<!doctype html>
<html>
<head>
    <meta charset="UTF-8">
    <title>测试</title>
</head>
<body>
    <canvas id="canvas" width="120" height="40"></canvas>
    <script>
        /**生成一个随机数**/
        function randomNum(min,max){
            return Math.floor( Math.random()*(max-min)+min);
        }
        /**生成一个随机色**/
        function randomColor(min,max){
            var r = randomNum(min,max);
            var g = randomNum(min,max);
            var b = randomNum(min,max);
            return "rgb("+r+","+g+","+b+")";
        }
        drawPic();
        document.getElementById("canvas").onclick = function(e){
            e.preventDefault();
            drawPic();
        }

        /**绘制验证码图片**/
        function drawPic(){
            var canvas=document.getElementById("canvas");
            var width=canvas.width;
            var height=canvas.height;
            var ctx = canvas.getContext('2d');
            ctx.textBaseline = 'bottom';

            /**绘制背景色**/
            ctx.fillStyle = randomColor(180,240); //颜色若太深可能导致看不清
            ctx.fillRect(0,0,width,height);
            /**绘制文字**/
            var str = 'ABCEFGHJKLMNPQRSTWXY123456789';
            for(var i=0; i<4; i++){
                var txt = str[randomNum(0,str.length)];
                ctx.fillStyle = randomColor(50,160);  //随机生成字体颜色
                ctx.font = randomNum(15,40)+'px SimHei'; //随机生成字体大小
                var x = 10+i*25;
                var y = randomNum(25,45);
                var deg = randomNum(-45, 45);
                //修改坐标原点和旋转角度
                ctx.translate(x,y);
                ctx.rotate(deg*Math.PI/180);
                ctx.fillText(txt, 0,0);
                //恢复坐标原点和旋转角度
                ctx.rotate(-deg*Math.PI/180);
                ctx.translate(-x,-y);
            }
            /**绘制干扰线**/
            for(var i=0; i<8; i++){
                ctx.strokeStyle = randomColor(40,180);
                ctx.beginPath();
                ctx.moveTo( randomNum(0,width), randomNum(0,height) );
                ctx.lineTo( randomNum(0,width), randomNum(0,height) );
                ctx.stroke();
            }
            /**绘制干扰点**/
            for(var i=0; i<100; i++){
                ctx.fillStyle = randomColor(0,255);
                ctx.beginPath();
                ctx.arc(randomNum(0,width),randomNum(0,height), 1, 0, 2*Math.PI);
                ctx.fill();
            }
        }
    </script>
</body>
</html>

在这里插入图片描述

图形验证码可验证
<!DOCTYPE html>
<html>
<!-- head -->
<head>
  <title>图片登录验证</title>
</head>
<body>
     <input type="text" value="" placeholder="请输入验证码(区分大小写)" 
	 style="height:43px;position: relative; top:-15px; font-size:20px;"id ="text">
     <canvas id="canvas" width="100" height="43" οnclick="dj()" 
	  style="border: 1px solid #ccc;
        border-radius: 5px;"></canvas>
     <button class="btn" οnclick="sublim()">提交</button>
    </body>
<script>
 var show_num = [];
 draw(show_num);
function dj(){
 draw(show_num);   
 }
function sublim(){
var val=document.getElementById("text").value;  
            var num = show_num.join("");
            if(val==''){
                alert('请输入验证码!');
            }else if(val == num){
                alert('提交成功!');
                document.getElementById(".input-val").val('');
                draw(show_num);

            }else{
                alert('验证码错误!\n你输入的是:  '+val+"\n正确的是:  "+num+'\n请重新输入!');
                document.getElementById("text").value='';
                draw(show_num);
            }
        
       
		
          }
function draw(show_num) {
        var canvas_width=document.getElementById('canvas').clientWidth;
        var canvas_height=document.getElementById('canvas').clientHeight;
        var canvas = document.getElementById("canvas");//获取到canvas的对象,演员
        var context = canvas.getContext("2d");//获取到canvas画图的环境,演员表演的舞台
        canvas.width = canvas_width;
        canvas.height = canvas_height;
        var sCode = "A,B,C,E,F,G,H,J,K,L,M,N,P,Q,R,S,T,W,X,Y,Z,1,2,3,4,5,6,7,8,9,0,q,w,e,r,t,y,u,i,o,p,a,s,d,f,g,h,j,k,l,z,x,c,v,b,n,m";
        var aCode = sCode.split(",");
        var aLength = aCode.length;//获取到数组的长度
			
        for (var i = 0; i <= 3; i++) {
            var j = Math.floor(Math.random() * aLength);//获取到随机的索引值
            var deg = Math.random() * 30 * Math.PI / 180;//产生0~30之间的随机弧度
            var txt = aCode[j];//得到随机的一个内容
            show_num[i] = txt;
            var x = 10 + i * 20;//文字在canvas上的x坐标
            var y = 20 + Math.random() * 8;//文字在canvas上的y坐标
            context.font = "bold 23px 微软雅黑";

            context.translate(x, y);
            context.rotate(deg);

            context.fillStyle = randomColor();
            context.fillText(txt, 0, 0);

            context.rotate(-deg);
            context.translate(-x, -y);
        }
        for (var i = 0; i <= 5; i++) { //验证码上显示线条
            context.strokeStyle = randomColor();
            context.beginPath();
            context.moveTo(Math.random() * canvas_width, Math.random() * canvas_height);
            context.lineTo(Math.random() * canvas_width, Math.random() * canvas_height);
            context.stroke();
        }
        for (var i = 0; i <= 30; i++) { //验证码上显示小点
            context.strokeStyle = randomColor();
            context.beginPath();
            var x = Math.random() * canvas_width;
            var y = Math.random() * canvas_height;
            context.moveTo(x, y);
            context.lineTo(x + 1, y + 1);
            context.stroke();
        }
    }
function randomColor() {//得到随机的颜色值
        var r = Math.floor(Math.random() * 256);
        var g = Math.floor(Math.random() * 256);
        var b = Math.floor(Math.random() * 256);
        return "rgb(" + r + "," + g + "," + b + ")";
    }
</script>
    
    
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值