本文主要是介绍Vue使用identify实现验证码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Vue使用identify实现验证码
- Identify
- identify.vue组件
- 组件引入
- 测试效果:
Identify
identify是一款使用使用canvas来生成图形验证码的vue插件。是一款使用使用canvas来生成图形验证码的vue插件。
npm i identify
identify.vue组件
在src/components文件夹创建SIdentify.vue
文件(用于定义参数和方法),复制以下代码:
<template><div class="s-canvas"><canvasid="s-canvas":width="contentWidth":height="contentHeight"></canvas></div>
</template>
<script>
export default {name: "SIdentify",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: 40,}},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>
组件引入
在需要的组件中引入identify.vue
组件
<template><div class="get-code" @click="refreshCode()"><s-identify :identify-code="identifyCode" /></div>
</template><script>
import SIdentify from "@/components/SIdentify.vue";
name: 'Login',
components: {SIdentify
},
data() {return {identifyCode: "",identifyCodes: "123456789abcdwerwshdjeJKDHRJHKOOPLMKQ",}
},
created() {this.refreshCode()
},
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)];}}
}
</script>
测试效果:
这篇关于Vue使用identify实现验证码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!