这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

使用Canvas绘制一个验证码组件

前言

验证码,这一日常伴随我们的要素,是我们在线交互的重要安全保障。你的手机短信里是否被它占据半壁江山,今天我们就来聊聊如何在网页上实现一个简单的验证码组件。大家在登录网站时为了防止被恶意攻击或者多次点击操作,使用验证码是最常用的实现方式。在学习完Canvas后,通过Canvas实现简单的验证码就比较简单了,该组件已开源上传npm,可以直接安装使用,源码已上传Git,地址在文尾。

聊聊Canvas

1、在开始绘制Canvas时,我们需要先创建一个html节点,并为其设置宽高

<canvas id="canvas" width="200" height="150""></canvas>

2、可以使用 cnv.width 和 cnv.height 分别获取 Canvas 的宽度和高度,可以使用 cnv.getContext("2d")来获取 canvas 2D 上下文环境对象。

如何绘制一条直线

使用canvas的 moveTo()和 lineTo()方法,比如将画笔moveTo(0,0),移动画笔到极点坐标,使用lineTo(100,100),这样执行完两个步骤将能够绘制一条从坐标(0,0)到坐标(100,100)的一条直线,不过此时canvas上并不会展示出一条直线,我们还需要调用stroke()方法结束绘画,这样就能在页面上看到一条直线。

随机画一条直线:

    context.moveTo(Math.random() * Canvas_DOM.width, Math.random() * Canvas_DOM.height);
context.lineTo(Math.random() * Canvas_DOM.width, Math.random() * Canvas_DOM.height);

如何绘制一个点

从上面我们知道了如何绘制一条直线,那么绘制一个点其实就是绘制一个长度为1的直线。

绘制一个随机点:

    var x = Math.random() * Canvas_DOM.width;
var y = Math.random() * Canvas_DOM.height;
context.moveTo(x, y);
context.lineTo(x + 1, y + 1);

怎么绘制文字

通过fillText(txt, 0, 0)就能在canvas里添加一个文字,其中txt为需要绘制的内容,后面两个参数为文字在canvas中的位置,当然也可以通过rotate()和translate()来改变文字的方向和位置。

    context.fillText(txt, 0, 0);
context.rotate(-deg);
context.translate(-x, -y);

使用fillStyle可以修改文字、线条的颜色

绘制验证码组件

从上面我们知道了如何绘制直线、点、以及文字,那么一个验证码也就由这些组成,我们只需要把他们结合起来,在点击验证码时,重新绘制一个随机的canvas,就能得到一个完整的验证码组件:

<template>
<canvas class="canvas" ref="cav" @click="Refresh"></canvas>
</template>
<script lang="ts" setup>
import { ref, onMounted } from 'vue';
const show_num = ref<any>([])
const cav = ref<any>(null)
onMounted(() => {
draw();
});
const draw = () => {
var Canvas_DOM = cav.value;
var cav_width = Canvas_DOM.clientWidth;
var cav_height = Canvas_DOM.clientHeight;
var context = Canvas_DOM.getContext('2d');
Canvas_DOM.width = cav_width;
Canvas_DOM.height = cav_height;
var sCode = "a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,1,2,3,4,5,6,7,8,9,0";
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.value[i] = txt.toLowerCase();
var x = 50 + 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_DOM.width, Math.random() * Canvas_DOM.height);
context.lineTo(Math.random() * Canvas_DOM.width, Math.random() * Canvas_DOM.height);
context.stroke();
}
for (var i = 0; i <= 30; i++) {
//验证码上显示随机小点
context.strokeStyle = _randomColor();
context.beginPath();
var x = Math.random() * Canvas_DOM.width;
var y = Math.random() * Canvas_DOM.height;
context.moveTo(x, y);
context.lineTo(x + 1, y + 1);
context.stroke();
}
}
const _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 + ')';
}
const Refresh = () => {
draw();
}
</script>
<style scoped>
.canvas {
width: 200px;
height: 40px;
display: inline-block;
margin-left: 12px;
cursor: pointer;
}
</style>

使用示例

npm install @fcli/vue-vercode --save-dev 来安装

在项目中使用
import VerCode from '@fcli/vue-vercode';
const app=createApp(App)
app.use(VerCode);

示例:

<div class="content">
<ver-code ref=verCode></ver-code>
</div>

获取验证码组件的数据

let code = verCode.value.show_num.join('');

本文转载于:

https://juejin.cn/post/7280786332712173626

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

记录--使用Canvas绘制一个验证码组件的更多相关文章

  1. canvas绘制随机验证码

    效果图: 思路: 1, 绘制canvas画布,进行基础设置 2.绘制一个矩形 3.设置验证码的随机数 4.设置验证码随机数的随机颜色 5.绘制随机干扰线 6,绘制随机干扰点 经过以上六个步骤,验证码的 ...

  2. 使用canvas绘制一个时钟

    周末学习canvas的一些基础功能,顺带写了一个基础的时钟.现在加工一下,做的更好看一点,先放上效果图: 谈一些自己的理解: (1).要绘制一个新的样式(不想被其他样式影响,或者影响到其他样式),那么 ...

  3. HTML5 在canvas绘制一个矩形

    笔者:本笃庆军 原文地址:http://blog.csdn.net/qingdujun/article/details/32930501 一.绘制矩形 canvas使用原点(0,0)在左上角的坐标系统 ...

  4. Canvas绘制一个大鱼喂小鱼的游戏

    Canvas是HTML5中的一部分,强大的API足以让我们绘制我们任意想绘制的东西.利用Canvas的基础学习以及JavaScript面向对象的思想绘制一个小游戏,下面是源码地址https://git ...

  5. 用canvas绘制一个简易时钟

    在见识了html5中canvas的强大,笔者准备制作一个简易时钟. 下面就是成果啦,制作之前我们先分析一下,绘制一个时钟需要做哪些准备. 一 . 1.首先这个时钟分为表盘,指针(时针,分针,秒针)和数 ...

  6. 用H5 Canvas绘制一个仪表盘笔记

    前端有许多做数据可视化的图表插件,但有时候UI设计的图可能用现成的js插件无法定制或者比较麻烦(还不如自己造轮子来的快). 下面记录下用H5 canvas设计一个仪表盘代码: <!DOCTYPE ...

  7. 利用canvas写一个验证码小功能

    刚刚开始接触canvas,写个验证码小功能练练手,实现效果图如下: 主要代码如下: html <!DOCTYPE html> <html lang="en"> ...

  8. 用canvas绘制一个时钟

    实现一个时钟的绘制和时间的显示 一,首先是页面的搭建html部分以及一点点的css代码,因为css这块用的比较少,所以就没有单独出来: <!DOCTYPE html> <html l ...

  9. Canvas 绘制一个像素风电子时钟

    想法是在 Canvas 上绘制由小方块组成的数字. 第一步是实现绘制小方块的方法,先画出一个边长为 5 的 10x10 个方块,使用两个 for 循环很简单就能完成. for (let i = 0; ...

  10. Canvas绘制图形

    1.Canvas绘制一个蓝色的矩形 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...

随机推荐

  1. python-命令行参数处理 getopt模块详解

    背景 在写脚本程序的时候需要添加一些额外的参数来实现脚本的附加功能或者增强功能,通常的做法是通过sys.argv[i]直接来获取参数的值,但是这个比较局限,要求参数的输入一定要按照顺序. fileNa ...

  2. Argocd学习

    argocd官网文档链接 ArgoCD官网文档 在K8S集群使用argocd命令将集群添加到argcd的cluster列表中 argocd cluster add kubernetes-admin@i ...

  3. CF510D Fox And Jumping

    题目链接 题目 见链接. 题解 方法一 知识点:背包dp,STL. 题目意思是让我们判断能否从这些数中选出一些数使得选的数公共gcd为 \(1\),如果可以输出最小花费. 一眼背包dp,但要map超大 ...

  4. Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列

    写在开头 队列是Java中的一个集合接口,之前的文章已经讲解了List和Set,那么今天就来唠一唠它吧.队列的特点:存储的元素是有序的.可重复的. 队列的两大接口Queue vs Deque Queu ...

  5. cookie和服务器Session的区别

    cookie和服务器Session的区别 cookie和服务器Session都可用来存储用户信息,cookie存放于客户端,Session存放于web服务器端. 因为cookie存放于客户端有可能被窃 ...

  6. shell之sort,uniq,cut,tr

    # sort主要是要理解域 # sort选项 -c 测试文件是否已经分类 -m 合并两个分类文件 -u 删除所有复制行 -o 存储sort结果的输出文件名 -b 使用域进行分类时,忽略第一个空格 -n ...

  7. 【生成对抗网络学习 其二】GAN(keras实现)代码阅读笔记

    想来想去还是记录一下吧,主要是怕以后时间长忘了 好记性不如烂笔头 代码来自eriklindernoren的开源GAN实现:https://github.com/eriklindernoren/Kera ...

  8. 基于图数据库 NebulaGraph 实现的欺诈检测方案及代码示例

    本文是一个基于 NebulaGraph 图算法.图数据库.机器学习.GNN 的 Fraud Detection 方法综述.在阅读本文了解欺诈检测的基本实现方法之余,也可以在我给大家准备的 Playgr ...

  9. vue使用cordova的大坑!!

    额,前段时间用 cordova 包了个 vue 项目,跑真机,完美.跑公司安卓系统虚拟机,垮. 原因找了很久,最后发现是路由的问题,使用了 createWebHistory ,去掉了 hash ,虽然 ...

  10. Python 潮流周刊第 41 期(摘要),赠书5本

    本周刊由 Python猫 出品,精心筛选国内外的 250+ 信息源,为你挑选最值得分享的文章.教程.开源项目.软件工具.播客和视频.热门话题等内容.愿景:帮助所有读者精进 Python 技术,并增长职 ...