效果展示

安装插件

npm i identify

定义组件 verificationCode.vue

<template>
<!-- 图形验证码 -->
<div class="s-canvas">
<canvas id="s-canvas" :width="contentWidth" :height="contentHeight"></canvas>
</div>
</template>
<script>
export default {
name: "verificationCode",
props: {
identifyCode: {
type: String,
default: "1234"
},
fontSizeMin: {
type: Number,
default: 35
},
fontSizeMax: {
type: Number,
default: 35
},
backgroundColorMin: {
type: Number,
default: 180
},
backgroundColorMax: {
type: Number,
default: 240
},
colorMin: {
type: Number,
default: 50
},
colorMax: {
type: Number,
default: 160
},
lineColorMin: {
type: Number,
default: 100
},
lineColorMax: {
type: Number,
default: 200
},
dotColorMin: {
type: Number,
default: 0
},
dotColorMax: {
type: Number,
default: 255
},
contentWidth: {
type: Number,
default: 120
},
contentHeight: {
type: Number,
default: 50
}
},
methods: {
// 生成一个随机数
randomNum(min, max) {
return Math.floor(Math.random() * (max - min) + min);
},
// 生成一个随机的颜色
randomColor(min, max) {
let r = this.randomNum(min, max);
let g = this.randomNum(min, max);
let b = this.randomNum(min, max);
return "rgb(" + r + "," + g + "," + b + ")";
},
transparent() {
return "rgb(255,255,255)";
},
drawPic() {
let canvas = document.getElementById("s-canvas");
let ctx = canvas.getContext("2d");
ctx.textBaseline = "bottom";
// 绘制背景
ctx.fillStyle = this.randomColor(
this.backgroundColorMin,
this.backgroundColorMax
);
ctx.fillStyle = this.transparent();
ctx.fillRect(0, 0, this.contentWidth, this.contentHeight);
// 绘制文字
for (let i = 0; i < this.identifyCode.length; i++) {
this.drawText(ctx, this.identifyCode[i], i);
}
// 绘制背景
this.drawLine(ctx)
this.drawDot(ctx)
},
drawText(ctx, txt, i) {
ctx.fillStyle = this.randomColor(this.colorMin, this.colorMax);
ctx.font =
this.randomNum(this.fontSizeMin, this.fontSizeMax) + "px SimHei";
let x = (i + 1) * (this.contentWidth / (this.identifyCode.length + 1));
let y = this.randomNum(this.fontSizeMax, this.contentHeight - 5);
var deg = this.randomNum(-10, 10);
// 修改坐标原点和旋转角度
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);
},
drawLine(ctx) {
// 绘制干扰线
for (let i = 0; i < 8; i++) {
ctx.strokeStyle = this.randomColor(
this.lineColorMin,
this.lineColorMax
);
ctx.beginPath();
ctx.moveTo(
this.randomNum(0, this.contentWidth),
this.randomNum(0, this.contentHeight)
);
ctx.lineTo(
this.randomNum(0, this.contentWidth),
this.randomNum(0, this.contentHeight)
);
ctx.stroke();
}
},
drawDot(ctx) {
// 绘制干扰点
for (let i = 0; i < 100; i++) {
ctx.fillStyle = this.randomColor(0, 255);
ctx.beginPath();
ctx.arc(
this.randomNum(0, this.contentWidth),
this.randomNum(0, this.contentHeight),
1,
0,
2 * Math.PI
);
ctx.fill();
}
}
},
watch: {
identifyCode() {
this.drawPic();
}
},
mounted() {
this.drawPic();
}
};
</script>

页面引用

<li class="inp_code">
<div class="sel-code">
<input type="text" placeholder="请输入验证码">
<div class="get-code" @click="refreshCode()">
<verificationCode:identifyCode="identifyCode"></verificationCode>
</div>
</div>
</li>

import SIdentify from '../../components/verificationCode'
components:{
verificationCode
},
data() {
return {
identifyCode: "",
identifyCodes: "0123456789abcdwerwshdjeJKDHRJHKOOPLMKQ"
}
},
methods: {
refreshCode() {
this.identifyCode = "";
this.makeCode(this.identifyCodes,4);
},
randomNum (min, max) {
max = max + 1
return Math.floor(Math.random() * (max - min) + min)
},
// 随机生成验证码字符串
makeCode (data, len) {
for (let i = 0; i < len; i++) {
this.identifyCode += data[this.randomNum(0, data.length - 1)]
}
}
},
mounted() {
this.refreshCode()//页面加载时就生成随机图形验证码
}

最新文章

  1. [GitHub] GitHub使用教程for Eclipse
  2. Servlet处理get请求时的中文乱码问题
  3. iOS 汉字转拼音
  4. iOS 程序启动原理
  5. Django学习笔记(二)——django数据库的使用
  6. 鸟哥的Linux私房菜学习笔记(1)
  7. [2013 ACM/ICPC Asia Regional Hangzhou Online J/1010]hdu 4747 Mex (线段树)
  8. eclipse下将普通的java工程转换成web工程
  9. c# 实现文件拖入和拖出(拖拽)
  10. apue
  11. 做自己的PHP语法解释器
  12. struts2相关简单介绍
  13. URL中特殊符号的处理
  14. 洛谷P3402 【模板】可持久化并查集(可持久化线段树,线段树)
  15. vue实现数据双向绑定的原理
  16. Windows10开机pin界面循环重启解决办法
  17. Codeforces 1062 E - Company
  18. Oracle数据库密码过期
  19. redis 学习记录
  20. DP - 字符混编

热门文章

  1. 初学《python编程从入门到实践》web应用程序,出现错误
  2. 洛谷P8508 做不完的作业【题解】
  3. 浅谈RMQ问题
  4. Python基本数据类型,用户交互,格式化输出,运算符,多种赋值方式,多种运算符
  5. 注解_概念-注解_JDK内置注解
  6. docker02-centos上安装
  7. P34_数据请求 - GET和POST请求
  8. javaweb画图
  9. 如何将项目打包成apk或exe程序
  10. 两台linux服务器互相自动备份