vue实现图片滑动验证功能——纯前端完成

*** 图片滑动验证,是目前比较常见的验证方式,主要目的是防止用户利用机器人自动注册、登录、灌水。目前vue技术日趋成熟,已经有专门针对图片滑动验证功能的插件了。具体使用方式如下:1.安装插件——npminstall–savevue-monoplasty-slide-verify注意此处的–save也就是简化版的-s,是为了将下载的插件保存到package.json中的depencedies中,这样其他人在下载你的项目后,依然可以通过npminstall将插件安装到node_modules.2***

在这里插入图片描述

大家好,又见面了,我是你们的朋友全栈君。

图片滑动验证,是目前比较常见的验证方式,主要目的是防止用户利用机器人自动注册、登录、灌水。
在这里插入图片描述
目前vue技术日趋成熟,已经有专门针对图片滑动验证功能的插件了。具体使用方式如下:

1.安装插件——npm install --save vue-monoplasty-slide-verify
注意此处的–save也就是简化版的-s,是为了将下载的插件保存到package.json中的depencedies中,这样其他人在下载你的项目后,依然可以通过npm install将插件安装到node_modules.

2.在main.js中引入插件并绑定到vue上

import Vue from 'vue';
import SlideVerify from 'vue-monoplasty-slide-verify';
 
Vue.use(SlideVerify);

3.封装图片验证组件

<template>
  <slide-verify
    :l="42"
    :r="10"
    :w="310"
    :h="155"
    :imgs="picArray"
    :show="false"
    slider-text="向右滑动完成验证"
    ref="slideverify"
    @success="onSuccess"
    @fail="onFail"
    @refresh="onRefresh"
  ></slide-verify>
</template>

<script>
export default { 
   
  name: "SliderVerify",
  data() { 
   
    return { 
   
      //在data中引入`assets`中的图片可以通过`require`的方式来引入
      picArray: [
        require("@/assets/verify/1.jpg"),
        require("@/assets/verify/2.jpg"),
        require("@/assets/verify/3.jpg"),
        require("@/assets/verify/4.jpg"),
        require("@/assets/verify/5.jpg"),
        require("@/assets/verify/6.jpg"),
        require("@/assets/verify/7.jpg"),
        require("@/assets/verify/8.jpg"),
      ],
    };
  },
  methods: { 
   
    onSuccess() { 
   //往父级传递验证通过的函数
      this.$emit("success");
    },
    onReset() { 
   //重置图片验证组件
      this.$refs.slideverify.reset();
    },
    onFail() { 
   },
    onRefresh() { 
   },
  },
};
</script>

4.父组件使用图片验证组件

import SlideVerify from "@/components/SlideVerify";//引入

export default { 
   
  name: "Redister",
  components: { 
   
    SlideVerify,//注册组件
  },
  data(){ 
   
  	return{ 
   
  		isShowSlide:false
  	}
  }
}

在html中使用组件

<div class="slideverify" v-show="isShowSlide" @mouseleave="hideSlide">
  <SlideVerify ref="slideblock" @success="sendSmsCode"></SlideVerify>
</div>

对应的js部分:

hideSlide() { 
   
  setTimeout(() => { 
   
    this.isShowSlide = false;
  }, 500);
},
sendSmsCode() { 
	//此处的处理是:图片验证通过后,发送短信验证码,这个要根据具体情况单独处理
  setTimeout(() => { 
   
    this.$api
      .getSendForgetSmsCode({ 
   
        mobile: this.form.account,
      })
      .then((res) => { 
   
        this.isShowSlide = false;
        if (res.data.success) { 
   
          this.timeCountDown();
          this.$message.success("短信验证码发送成功");
        } else { 
   
          this.$message.error(res.data);
        }
      })
      .catch((err) => { 
   });
  }, 500);
},
   
	//此处的处理是:图片验证通过后,发送短信验证码,这个要根据具体情况单独处理
  setTimeout(() => { 
   
    this.$api
      .getSendForgetSmsCode({ 
   
        mobile: this.form.account,
      })
      .then((res) => { 
   
        this.isShowSlide = false;
        if (res.data.success) { 
   
          this.timeCountDown();
          this.$message.success("短信验证码发送成功");
        } else { 
   
          this.$message.error(res.data);
        }
      })
      .catch((err) => { 
   });
  }, 500);
},

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/129320.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力回答您的问题。针对您的问题,可以使用以下步骤实现: 1.在Vue3项目中,安装 `vue-recaptcha` 包,这个包实现了谷歌验证功能。 2.在 `index.html` 文件中,引入次包需要的JS文件,如下所示: ```html <script src="https://www.google.com/recaptcha/api.js?render=reCAPTCHA_site_key"></script> ``` 其中 `reCAPTCHA_site_key` 是您在谷歌开发者网站上申请的Site key。 3.在 `App.vue` 中,添加如下代码: ```html <template> <div> <div ref="captcha"></div> <button @click="verify">Verify</button> </div> </template> <script> import { ref } from 'vue'; import { createRecaptcha } from 'vue-recaptcha'; export default { setup() { const captchaRef = ref(null); let captchaToken = null; // 创建recaptcha实例,并记录token createRecaptcha({ siteKey: 'reCAPTCHA_site_key', size: 'normal', container: captchaRef.value, badge: 'inline', callback: function (token) { captchaToken = token; }, }); function verify() { // 发送captchaToken 到后端进行验证 console.log(captchaToken); } return { captchaRef, verify }; }, }; </script> ``` 在 `createRecaptcha` 方法中,我们可以设置一些参数来指定验证码组件的属性,如 `siteKey`、`size`、`container`、`badge` 以及 `callback` 等等。这里的 `callback` 方法会在用户成功进行验证后被调用,返回一个token参数,可以在后端使用来验证验证码是否正确。 4.在后端中,通过接收到的 `captchaToken` 参数,向谷歌服务器发送请求来验证用户的验证码是否正确。如果正确,后端可以返回一个成功的信息给前端,否则返回一个失败的信息。 以上就是使用 `vue-recaptcha` 包来实现验证验证的方法。希望对您有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值