如何解決Vue微信授權登入前後端分離的問題
這篇文章主要介紹了詳解Vue微信授權登入前後端分離較為優雅的解決方案,內容挺不錯的,現在分享給大家,也給大家做個參考。
微信授權登入是一個非常常見的場景,利用微信授權登入,我們可以很容易取得使用者的一些資訊,透過使用者對公眾號的唯一openid從而建立資料庫綁定使用者身分。
微信授權登入的機制這裡不做詳述,微信官方文件已有詳述,簡述就是透過跳轉微信授權的頁面,使用者點擊確認後,微信會跳到回呼頁面,此時回呼頁面url上會攜帶code參數,透過code參數,後端可以拿code換取擁護openid,或使用者資訊
在vue專案中,通常是一個SPA應用程式,也就是所有的頁面都是同一個html,通常現在開發也是前後端徹底分離的,vue打包後生成的純靜態文件,甚至可以不經過伺服器,所以透過後端弄跳轉之類的都不太優雅,本文即介紹此類場景的微信授權登入
對於一個vue的SPA應用程式,我們通常可能有很多頁面,在微信公眾號上我們可能配置多個選單,多個選單對應vue的路由頁面,但是可能並不是每個頁面都需要使用者授權才能進入,有些頁面使用者不登入也需要可以預覽,此時我們可以透過vue router來實現前端路由攔截
router.beforeEach(async (to, from, next) => { if (to.matched.some(recode => recode.meta.noAuth)) { next() } else { // store已存在用户信息直接进入页面 if (store.state.userInfo.nickname) { next() return } const code = getUrl(window.location.href).code // 截取url上的code ,可能没有,则返回''空字符串 let res = await api.post('/imsl/user/user-auth', [code]) // 获取用户信息,后端可首先通过cookie,session等判断,没有信息则通过code获取 console.log(res) // 返回用户信息 if (res.code === 200 && res.data.is_auth) { store.commit('setUserInfo', res.data) next() } else { // 此状态根据业务需求 可能不存在 if (res.code === 201) { const openid = res.data.openid console.log(openid) store.commit('setOpenid', openid) localStorage.setItem('openid', openid) next('/enlist-info') } // 上面的获取用户信息接口,如果cookie,session拿不到用户信息,且传递的code为空,则跳转到微信授权页面 if (res.code === 202) { console.log(window.location.origin) console.log(to.fullPath) // 这个redirectUrl用 当前页路径或者tof.fullPath(将要进入的路径) let redirectUrl = window.location.href redirectUrl = encodeURIComponent(redirectUrl) console.log(redirectUrl) const appid='wxdff0642c2120ea39' window.location.href = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${redirectUrl}&response_type=code&scope=snsapi_userinfo&state=123#wechat_redirect` } } } })
上述程式碼基本闡述了一個授權的過程,首先,我們在設定vue路由的時候,設定此路由是否需要登入即給router的meta加一個noAuth:true的屬性,這個是處理不需要登入的頁面,透過router.beforeEach進行判斷,如果是不需要登入的頁面:noAuth,則直接next()讓其進入對應頁面.對於需要登入的頁面,則讓後端配合,此時,後端寫一個取得使用者資訊的介面,前端則直接呼叫取得使用者資訊的介面,當然,不需要每個頁面都調用,獲取一次之後可以將用戶資訊存入vuex中,所以通過判斷vuex裡面有沒有用戶信息,如果已存在用戶信息,則進入頁面.沒有用戶信息那就調用後端獲取用戶資訊的介面,說到這裡,終於回到此文主題了,用戶資訊是透過微信授權登入拿到的,此時後端如何拿到用戶資訊呢?這裡,可以跟後端商議好,用戶綁定身分後,後端則可以透過設定cookie,token之類的來儲存這個使用者登入狀態,如果有相關狀態,那麼後端則可以直接傳回使用者資訊. 如果是首次進入,或cookie,token之類的已失效,那麼此時則會呼叫微信授權登入了,如上述程式碼所述,分為三種情況,
#1. 透過cookie,token等,後端直接拿到了使用者資訊,此時則拿到使用者資訊直接進入頁面,同時把使用者資訊存入vuex中
2. 沒有使用者資訊的情況,此時也沒有cookie,token,那就需要重新調用微信授權登入了,上面給出的兩種回傳碼code=201,code=202的情況,當code=2是則由前端直接跳到微信授權頁面,而redirectUri則為將要進入的頁面,此時會發生什麼事呢?會跳到微信授權頁面,用戶點擊之後又回到了這個頁面,不同的是此時url上面已經攜帶了code,前端通過字符串截取拿到code,發送給後端,後端即可透過code換取openid以及使用者資訊了.
總結:
- ##專案採用前後端完全分離方式,即打包後給的純靜態檔案放在伺服器,存取index.html
- #後端不在介面處攔截,不需要後端跳轉微信授權登入頁面,由前端路由來攔截跳轉,實現方法如3.
- 前端在需要用戶身份才能進入的頁面通過vue-router的router.beforeEach鉤子函數攔截,此時調用獲取用戶資訊介面,後端首先透過取得cookie,token等判斷使用者,無相關資訊返回201或202,當返回202的時候,前端跳到微信授權頁,redirecturi即為要進入的頁面的url,跳轉授權後微信會在url上面攜帶code回到當前頁,此時前端截取url上的code傳給後端,後端透過code在後端處理拿到用戶資訊,openid等實現了授權登入
##
以上是如何解決Vue微信授權登入前後端分離的問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

可以通過以下步驟為 Vue 按鈕添加函數:將 HTML 模板中的按鈕綁定到一個方法。在 Vue 實例中定義該方法並編寫函數邏輯。

Vue.js 中的 watch 選項允許開發者監聽特定數據的變化。當數據發生變化時,watch 會觸發一個回調函數,用於執行更新視圖或其他任務。其配置選項包括 immediate,用於指定是否立即執行回調,以及 deep,用於指定是否遞歸監聽對像或數組的更改。

Vue 多頁面開發是一種使用 Vue.js 框架構建應用程序的方法,其中應用程序被劃分為獨立的頁面:代碼維護性:將應用程序拆分為多個頁面可以使代碼更易於管理和維護。模塊化:每個頁面都可以作為獨立的模塊,便於重用和替換。路由簡單:頁面之間的導航可以通過簡單的路由配置來管理。 SEO 優化:每個頁面都有自己的 URL,這有助於搜索引擎優化。

在 Vue.js 中引用 JS 文件的方法有三種:直接使用 <script> 標籤指定路徑;利用 mounted() 生命週期鉤子動態導入;通過 Vuex 狀態管理庫進行導入。

Vue.js 返回上一頁有四種方法:$router.go(-1)$router.back()使用 <router-link to="/"> 組件window.history.back(),方法選擇取決於場景。

Vue.js 遍歷數組和對像有三種常見方法:v-for 指令用於遍歷每個元素並渲染模板;v-bind 指令可與 v-for 一起使用,為每個元素動態設置屬性值;.map 方法可將數組元素轉換為新數組。

Vue 中 div 元素跳轉的方法有兩種:使用 Vue Router,添加 router-link 組件。添加 @click 事件監聽器,調用 this.$router.push() 方法跳轉。
