Maison  >  Article  >  interface Web  >  Comment implémenter le code de vérification dans vue

Comment implémenter le code de vérification dans vue

藏色散人
藏色散人original
2021-11-02 15:06:458609parcourir

Vue implémente des méthodes de code de vérification : 1. Créer des composants js ; 2. Introduire des composants ; 3. Définir des objets de vérification ; 5. Vérifier si l'entrée est correcte via la méthode validate().

Comment implémenter le code de vérification dans vue

L'environnement d'exploitation de cet article : système Windows 7, vue version 2.9.6, ordinateur DELL G3.

Comment vue implémente le code de vérification

Vue implémente la fonction de code de vérification

Le contenu spécifique est le suivant

1 Effet

Comment implémenter le code de vérification dans vue

2.1 Créer un composant js

.

Comment implémenter le code de vérification dans vueContenu

(Vous pouvez le coller directement, vous devez changer la largeur et la hauteur, modifier la largeur et la hauteur dans la méthode _init)

function GVerify (options) { // 创建一个图形验证码对象,接收options对象为参数
 this.options = { // 默认options参数值
  id: '', // 容器Id
  canvasId: 'verifyCanvas', // canvas的ID
  width: '80', // 默认canvas宽度
  height: '30', // 默认canvas高度
  type: 'number', // 图形验证码默认类型blend:数字字母混合类型、number:纯数字、letter:纯字母
  code: ''
 }
 
 if (Object.prototype.toString.call(options) === '[object Object]') { // 判断传入参数类型
  for (var i in options) { // 根据传入的参数,修改默认参数值
   this.options[i] = options[i]
  }
 } else {
  this.options.id = options
 }
 
 this.options.numArr = '0,1,2,3,4,5,6,7,8,9'.split(',')
 this.options.letterArr = getAllLetter()
 
 this._init()
 this.refresh()
}
 
GVerify.prototype = {
 /** 版本号**/
 version: '1.0.0',
 
 /** 初始化方法**/
 _init: function () {
  var con = document.getElementById(this.options.id)
  var canvas = document.createElement('canvas')
  // this.options.width = con.offsetWidth > 0 ? con.offsetWidth : '30'
  // this.options.height = con.offsetHeight > 0 ? con.offsetHeight : '30'
  this.options.width = '160'
  this.options.height = '50'
  canvas.id = this.options.canvasId
  canvas.width = this.options.width
  canvas.height = this.options.height
  canvas.style.cursor = 'pointer'
  canvas.innerHTML = '您的浏览器版本不支持canvas'
  con.appendChild(canvas)
  var parent = this
  canvas.onclick = function () {
   parent.refresh()
  }
 },
 
 /** 生成验证码**/
 refresh: function () {
  var canvas = document.getElementById(this.options.canvasId)
  if (canvas.getContext) {
   var ctx = canvas.getContext('2d')
  }
  ctx.textBaseline = 'middle'
 
  ctx.fillStyle = randomColor(180, 240)
  ctx.fillRect(0, 0, this.options.width, this.options.height)
 
  if (this.options.type === 'blend') { // 判断验证码类型
   var txtArr = this.options.numArr.concat(this.options.letterArr)
  } else if (this.options.type === 'number') {
   var txtArr = this.options.numArr
  } else {
   var txtArr = this.options.letterArr
  }
 
  for (var i = 1; i <= 4; i++) {
   var txt = txtArr[randomNum(0, txtArr.length)]
   this.options.code += txt
   ctx.font = randomNum(this.options.height / 2, this.options.height) + &#39;px SimHei&#39; // 随机生成字体大小
   ctx.fillStyle = randomColor(50, 160) // 随机生成字体颜色
   ctx.shadowOffsetX = randomNum(-3, 3)
   ctx.shadowOffsetY = randomNum(-3, 3)
   ctx.shadowBlur = randomNum(-3, 3)
   ctx.shadowColor = &#39;rgba(0, 0, 0, 0.3)&#39;
   var x = this.options.width / 5 * i
   var y = this.options.height / 2
   var deg = randomNum(-30, 30)
   /** 设置旋转角度和坐标原点**/
   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 < 4; i++) {
   ctx.strokeStyle = randomColor(40, 180)
   ctx.beginPath()
   ctx.moveTo(randomNum(0, this.options.width), randomNum(0, this.options.height))
   ctx.lineTo(randomNum(0, this.options.width), randomNum(0, this.options.height))
   ctx.stroke()
  }
  /** 绘制干扰点**/
  for (var i = 0; i < this.options.width / 4; i++) {
   ctx.fillStyle = randomColor(0, 255)
   ctx.beginPath()
   ctx.arc(randomNum(0, this.options.width), randomNum(0, this.options.height), 1, 0, 2 * Math.PI)
   ctx.fill()
  }
 },
 
 /** 验证验证码**/
 validate: function (code) {
  var code = code.toLowerCase()
  var v_code = this.options.code.toLowerCase()
  if (code == v_code) {
   return true
  } else {
   return false
  }
 }
}
/** 生成字母数组**/
function getAllLetter () {
 var letterStr = &#39;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&#39;
 return letterStr.split(&#39;,&#39;)
}
/** 生成一个随机数**/
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 &#39;rgb(&#39; + r + &#39;,&#39; + g + &#39;,&#39; + b + &#39;)&#39;
}
 
export {
 GVerify
}

2.2 Page de connexion

2.2.1 Introduire les composants

[....<script>]
 
import { GVerify } from &#39;../../static/js/verifyCode&#39;;
 
[export default { ....]

2.2.2 Définir l'objet de vérification

Faites attention à verifyCode

data: function () {
  return {
   title: &#39;若晨后台管理系统&#39;,
   ruleForm: {
    username: &#39;&#39;,
    password: &#39;&#39;,
    verifyCode: &#39;&#39;
   },
   rules: {
    username: [
     { required: true, message: &#39;请输入用户名&#39;, trigger: &#39;blur&#39; }
    ],
    password: [{ required: true, message: &#39;请输入密码&#39;, trigger: &#39;blur&#39; }],
    verifyCode: [
     { required: true, message: &#39;请输入验证码&#39;, trigger: &#39;blur&#39; }
    ]
   },
   verifyCode: null
  }
 },

2.2.3 Initialisez le nœud

<el-form-item prop="verifyCode" class="verifyCodeItemCss">
     <el-input class="verify_css" placeholder="请输入4位验证码" v-model="ruleForm.verifyCode" @keyup.enter.native="submitForm(&#39;ruleForm&#39;)"></el-input>
     <!--关键 ↓-->
     <div id="v_container"></div>
</el-form-item>

Dans la méthode montée, initialisez 'v_container' comme identifiant du div

mounted () {
  this.verifyCode = new GVerify(&#39;v_container&#39;)
}

2.2.4 Vérifiez si l'entrée est correcte

Grâce à la méthode validate() de l'objet verifyCode défini dans data, si l'entrée Correct renvoie true, l'erreur renvoie false

var that = this
 
   // 获取验证码
   var verifyCode = this.ruleForm.verifyCode
   var verifyFlag = this.verifyCode.validate(verifyCode)
   if (!verifyFlag) {
    that.$notify.error({
     title: &#39;系统提示&#39;,
     message: &#39;验证码输入错误&#39;
    })
    return;
   } else {
    that.$notify({
     title: &#39;系统提示&#39;,
     message: &#39;验证码输入正确&#39;,
     type: &#39;success&#39;
    })
   }

3 Tous les codes de page


 
<script>
import { GVerify } from &#39;../../static/js/verifyCode&#39;;
export default {
 data: function () {
  return {
   title: &amp;#39;若晨后台管理系统&amp;#39;,
   ruleForm: {
    username: &amp;#39;&amp;#39;,
    password: &amp;#39;&amp;#39;,
    verifyCode: &amp;#39;&amp;#39;
   },
   rules: {
    username: [
     { required: true, message: &amp;#39;请输入用户名&amp;#39;, trigger: &amp;#39;blur&amp;#39; }
    ],
    password: [{ required: true, message: &amp;#39;请输入密码&amp;#39;, trigger: &amp;#39;blur&amp;#39; }],
    verifyCode: [
     { required: true, message: &amp;#39;请输入验证码&amp;#39;, trigger: &amp;#39;blur&amp;#39; }
    ]
   },
   verifyCode: null
  }
 },
 mounted () {
  // 随机播放帧数
  this.videoCut()
 
  this.verifyCode = new GVerify(&#39;v_container&#39;)
 },
 methods: {
  submitForm (formName) {
   var that = this
 
   // 获取验证码
   var verifyCode = this.ruleForm.verifyCode
   var verifyFlag = this.verifyCode.validate(verifyCode)
   if (!verifyFlag) {
    that.$notify.error({
     title: &amp;#39;系统提示&amp;#39;,
     message: &amp;#39;验证码输入错误&amp;#39;
    })
    return;
   } else {
    that.$notify({
     title: &amp;#39;系统提示&amp;#39;,
     message: &amp;#39;验证码输入正确&amp;#39;,
     type: &amp;#39;success&amp;#39;
    })
   }
 
   this.$refs[formName].validate(valid => {
    if (valid) {
     // 判断是否登录成功
 
     let param = {
      userName: that.ruleForm.username,
      passWord: that.ruleForm.password
     }
 
     // this.axios.post(this.$service.user.USER_LOGIN_API.url,param).then(res=>{
     //   console.log("请求成功",res)
     //   if(res.data.data != undefined){
     //     that.$notify({
     //       title: &#39;系统提示&#39;,
     //       message: &#39;登录成功&#39;,
     //       type:"success"
     //     });
     //           // 存local
     //     localStorage.setItem(&#39;ms_username&#39;,res.data.data.userNickName);
     //     localStorage.setItem(&#39;token&#39;,res.data.data.id);
     //     self.$router.push(&#39;/index&#39;);
     //   }else{
     //     that.$notify.error({
     //     title: &#39;系统提示&#39;,
     //     message: &#39;用户账户密码输出错误&#39;
     //     });
     //   }
 
     localStorage.setItem(&#39;ms_username&#39;, &#39;admin&#39;)
     localStorage.setItem(&#39;token&#39;, &#39;admin&#39;)
     that.$router.push(&#39;/index&#39;)
    } else {
     console.log(&#39;error submit!!&#39;)
     return false
    }
   })
  },
 
  videoCut () {
   $(&#39;video&#39;).on(&#39;loadedmetadata&#39;, function (event) {
    var duration = Math.ceil(this.duration)
    this.currentTime = Math.round(Math.random() * duration)
   })
  }
 }
}
</script>
 
 

Apprentissage recommandé : "

Les 5 dernières sélections du didacticiel vidéo vue.js

".

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn