中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue PC端怎么實現掃碼登錄功能

發布時間:2023-01-31 10:15:15 來源:億速云 閱讀:194 作者:iii 欄目:編程語言

本文小編為大家詳細介紹“Vue PC端怎么實現掃碼登錄功能”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Vue PC端怎么實現掃碼登錄功能”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

需求描述

目前大多數PC端應用都有配套的移動端APP,如微信,淘寶等,通過使用手機APP上的掃一掃功能去掃頁面二維碼圖片進行登錄,使得用戶登錄操作更方便,安全,快捷。

思路解析

PC 掃碼原理?

掃碼登錄功能涉及到網頁端、服務器和手機端,三端之間交互大致步驟如下:

  • 網頁端展示二維碼,同時不斷的向服務端發送請求詢問該二維碼的狀態;

  • 手機端掃描二維碼,讀取二維碼成功后,跳轉至確認登錄頁,若用戶確認登錄,則服務器修改二維碼狀態,并返回用戶登錄信息;

  • 網頁端收到服務器端二維碼狀態改變,則跳轉登錄后頁面;

  • 若超過一定時間用戶未操作,網頁端二維碼失效,需要重新刷新生成新的二維碼。

前端功能實現

如何生成二維碼圖片?

  • 二維碼內容是一段字符串,可以使用uuid 作為二維碼的唯一標識;

  • 使用qrcode插件 import QRCode from 'qrcode'; 把uuid變為二維碼展示給用戶

import {v4 as uuidv4} from "uuid"
import QRCode from "qrcodejs2"
 let timeStamp = new Date().getTime() // 生成時間戳,用于后臺校驗有效期
 let uuid = uuidv4()
 let content = `uid=${uid}&timeStamp=${timeStamp}`
 this.$nextTick(()=> {
     const qrcode = new QRCode(this.$refs.qrcode, {
       text: content,
       width: 180,
       height: 180,
       colorDark: "#333333",
       colorlight: "#ffffff",
       correctLevel: QRCode.correctLevel.H,
       render: "canvas"
     })
     qrcode._el.title = ''

如何控制二維碼的時效性?

使用前端計時器setInterval, 初始化有效時間effectiveTime,  倒計時失效后重新刷新二維碼

export default {
  name: "qrCode",
  data() {
    return {
      codeStatus: 1, // 1- 未掃碼 2-掃碼通過 3-過期
      effectiveTime: 30, // 有效時間
      qrCodeTimer: null // 有效時長計時器
      uid: '',
      time: ''
    };
  },

  methods: {
    // 輪詢獲取二維碼狀態
    getQcodeStatus() {
      if(!this.qsCodeTimer) {
        this.qrCodeTimer = setInterval(()=> {
          // 二維碼過期
          if(this.effectiveTime <=0) {
            this.codeStatus = 3
            clearInterval(this.qsCodeTimer)
            this.qsCodeTimer = null
            return
          }
          this.effectiveTime--
        }, 1000)
      }

    },
   
    // 刷新二維碼
    refreshCode() {
      this.codeStatus = 1
      this.effectiveTime = 30
      this.qsCodeTimer = null
      this.generateORCode()
    }
  },

前端如何獲取服務器二維碼的狀態?

前端向服務端發送二維碼狀態查詢請求,通常使用輪詢的方式

  • 定時輪詢:間隔1s 或特定時段發送請求,通過調用setInterval(), clearInterval()來停止;

  • 長輪詢:前端判斷接收到的返回結果,若二維碼仍未被掃描,則會繼續發送查詢請求,直至狀態發生變化(失效或掃碼成功)

  • Websocket:前端在生成二維碼后,會與后端建立連接,一旦后端發現二維碼狀態變化,可直接通過建立的連接主動推送信息給前端。

使用長輪詢實現:

 // 獲取后臺狀態
    async checkQRcodeStatus() {
       const res = await checkQRcode({
         uid: this.uid,
         time: this.time
       })
       if(res && res.code == 200) {
         let codeStatus - res.codeStatus
         this.codeStatus =  codeStatus
         let loginData = res.loginData
         switch(codeStatus) {
           case 3:
              console.log("二維碼過期")
              clearInterval(this.qsCodeTimer)
              this.qsCodeTimer = null
              this.effectiveTime = 0
            break;
            case 2:
              console.log("掃碼通過")
              clearInterval(this.qsCodeTimer)
              this.qsCodeTimer = null
              this.$emit("login", loginData)
            break;
            case 1:
              console.log("未掃碼")
              this.effectiveTime > 0  && this.checkQRcodeStatus()
            break;
            default:
            break;
         }
       } 
    },

讀到這里,這篇“Vue PC端怎么實現掃碼登錄功能”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

太白县| 五华县| 桃江县| 开平市| 揭西县| 肃宁县| 耒阳市| 依兰县| 西安市| 昌图县| 保靖县| 珲春市| 城口县| 邵武市| 甘孜| 莲花县| 铁岭市| 五寨县| 西乡县| 广南县| 三江| 云林县| 普陀区| 清水河县| 涿州市| 宣威市| 平陆县| 龙州县| 兰州市| 天祝| 突泉县| 西乡县| 西充县| 陇川县| 绵阳市| 忻城县| 邵东县| 苍南县| 普兰店市| 泾川县| 梁河县|