成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

vue+typescript+極驗登錄驗證的實現(xiàn)方法

此功能基于vue(v2.6.8) + typescript(v3.3.3333), 引入極驗(geetest v3+)(官方api),使用其product: 'bind'模式, 頁面掛載后初始化ininGeetest,點擊登錄按鈕后先做表單驗證,通過后彈出滑塊框,拖動驗證成功,執(zhí)行登錄方法。

創(chuàng)新互聯(lián)為客戶提供專業(yè)的成都網(wǎng)站設(shè)計、成都做網(wǎng)站、程序、域名、空間一條龍服務(wù),提供基于WEB的系統(tǒng)開發(fā). 服務(wù)項目涵蓋了網(wǎng)頁設(shè)計、網(wǎng)站程序開發(fā)、WEB系統(tǒng)開發(fā)、微信二次開發(fā)、移動網(wǎng)站建設(shè)等網(wǎng)站方面業(yè)務(wù)。

本項目為前后端分離,所以后端部署部分,請自行參考文檔操作

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

后臺接口:

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

開始:/public/js目錄添加 jquery-1.12.3.min.js文件 和 gt.js(下載)在/public/index.html中引入以上添加的兩個文件login.vue使用注意事項:要注意在gt.js中,initGeetest已被掛載到window對象

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

頁面可能報錯: Uncaught SyntaxError: Unexpected token <

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

vue + typescript + 極驗登錄驗證的實現(xiàn)方法

將報錯對象添加到與public同級的static目錄下(沒有則新建),修改引入路徑即可。

源碼:

<script lang="ts">
import { isValidUsername } from '@/utils/validate';
import { Component, Vue, Watch } from 'vue-property-decorator';
import { Route } from 'vue-router';
import { ElForm } from 'element-ui/types/form';
import { Loading } from 'element-ui';

import { Action } from 'vuex-class';
import AuthServices from '@/services/user/auth.ts';
import ThirdpartyServices from '@/services/thirdparty/index.ts';

const validateUsername = (rule: any, value: string, callback: any) => {
 if (! value) {
  callback(new Error('用戶名不能為空'));
 // } else if (!isValidUsername(value)) {
 //  callback(new Error('請輸入正確的用戶名'));
 } else {
  callback();
 }
};
const validatePass = (rule: any, value: string, callback: any) => {
  if (! value) {
  callback(new Error('密碼不能為空'));
 // } else if (value.length < 5) {
 //  callback(new Error('密碼不能小于5位'));
 } else {
  callback();
 }
};

@Component({
 name: 'login',
})
export default class Login extends Vue {
 @Action('auth/login') private login_action!: CCS.LoginAction;

 private loginForm = { username: '', password: '' };
 private loginRules = {
  username: [{trigger: 'blur', validator: validateUsername }],
  password: [{trigger: 'blur', validator: validatePass }],
 };
 private loading = false;
 private redirect: string | undefined = undefined;
 private captchaEntity: any;
 // private loadingInstance: any;

 @Watch('$route', { immediate: true }) private OnRouteChange(route: Route) {
  this.redirect = route.query && route.query.redirect as string;
 }

 // private created() {
 //  this.loadingInstance = Loading.service({
 //   customClass: 'login_loading',
 //   text: '正在初始化,請稍后',
 //   fullscreen: true,
 //   lock: true,
 //  });
 // }

 /** ==================== 驗證 START ========================= */
 /**
  * 頁面掛載后,后臺獲取初始化initGeetest所需參數(shù)值
  */
 private async mounted() {
  ThirdpartyServices.geetest_init().then((result) => {
   // this.loadingInstance.close();
   if (result.status) {
    this.initGeetest(result.data);
   } else {
    this.$message({ type: 'error', message: result.message });
   }
  });
 }
  /**
  * initGeetest 初始化
  */
 private initGeetest(param: CCS.GeettestInitType) {
  if ( ! (window as any) || ! (window as any).initGeetest ) {
   return false;
  }
  (window as any).initGeetest({
   gt: param.gt,
   challenge: param.challenge,
   offline: ! param.success,
   new_captcha: param.newcaptcha,
   timeout: '5000',
   product: 'bind',
   width: '300px',
   https: true,

  }, this.captchaObj_callback);
 }
 /**
  * 初始化后的回調(diào)函數(shù)
  */
 private async captchaObj_callback(captchaObj: any) {
  this.captchaEntity = captchaObj; // promise對象
  captchaObj
   .onReady(() => { // 驗證碼就位
   })
   .onSuccess(() => {
    const rst = captchaObj.getValidate();
    if (!rst) {
     this.$message({ type: 'warning', message: '請完成驗證'});
    }

    // 調(diào)用后臺check this.captchaObj
    this.verify_check(rst);
   })
   .onError((err: Error) => {
    console.log(err);
   });
 }
 /**
  * 后臺驗證初始化結(jié)果
  */
 private async verify_check(validateResult: any) {
  ThirdpartyServices.geetest_checked(validateResult.geetest_challenge, validateResult.geetest_validate, validateResult.geetest_seccode ).then((result) => {
   if (result.status && result.data.result) {
    // 驗證通過,發(fā)送登錄請求
    this.handleLogin(result.data.token);
   } else {
    this.$message({ type: 'error', message: '驗證失敗'});
    return false;
   }
  });
 }
 /** ==================== 驗證 END ========================= */
 /**
  * 點擊登錄按鈕,彈出驗證框
  */
 private login_btn_click() {
  (this.$refs.refform as ElForm).validate((valid) => {
   if (valid) {
    this.captchaEntity.verify(); // 顯示驗證碼
   }
  });
 }
 /**
  * 驗證成功,發(fā)送登錄請求
  */
 private async handleLogin(token: string) {
  this.loading = true;
  const { status, message} = await this.login_action({username: this.loginForm.username.trim(), password: this.loginForm.password, token});

  this.loading = false;
  if (status) {
   this.$message({type: 'success', message: '登錄成功'});
   this.$router.push({ path: this.redirect || '/' });
  } else {
   this.$message({type: 'error', message});
  }
 }
}
</script>

<template>
 <div class="login-container">
  <div class="login_form_wraper">
   <div class="logo_show">
    <img :src="require('@/assets/images/logo_w328.png')">
   </div>
   <img class="form_bg" :src="require('@/assets/images/login_form.png')">
   <el-form ref="refform" class="login-form" auto-complete="on" label-position="left"
     :model="loginForm" :rules="loginRules">
    <el-form-item prop="username">
     <el-input v-model="loginForm.username" name="username" type="text" auto-complete="on" placeholder="用戶名"/>
     <i class="iconfont icon-zhanghaodenglu icon_prefix"></i>
    </el-form-item>
    <el-form-item prop="password">
     <el-input v-model="loginForm.password" name="password" type="password" auto-complete="on" placeholder="密碼"
      @keyup.enter.native="handleLogin" />
     <i class="iconfont icon-mima icon_prefix"></i>
    </el-form-item>

    <el-form-item class="login_btn">
     <el-button v-if="!loading" @click.native.prevent="login_btn_click">登錄</el-button>
     <el-button :loading="loading" v-else @click.native.prevent="handleLogin">登錄中</el-button>
    </el-form-item>
   </el-form>

  </div>
 </div>
</template>

<style lang="stylus" scoped>
@import '~@/assets/styles/var.styl';
@import '~@/assets/styles/pages/login.styl';

.login-container
 pass

</style>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

文章題目:vue+typescript+極驗登錄驗證的實現(xiàn)方法
分享網(wǎng)址:http://jinyejixie.com/article36/gdpepg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、服務(wù)器托管、網(wǎng)站設(shè)計做網(wǎng)站、網(wǎng)站維護(hù)、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
黄平县| 红河县| 娄底市| 陈巴尔虎旗| 拜城县| 乐东| 久治县| 克拉玛依市| 庆元县| 翁牛特旗| 商水县| 泰兴市| 吉木萨尔县| 白河县| 涪陵区| 大宁县| 德令哈市| 民乐县| 松桃| 靖安县| 英吉沙县| 临颍县| 岫岩| 依兰县| 鄢陵县| 拜城县| 高台县| 天气| 韶山市| 贵州省| 郸城县| 壤塘县| 营山县| 乐业县| 双流县| 渑池县| 兰考县| 平定县| 望都县| 三原县| 桑植县|