欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Vue微信授權(quán)登錄前后端分離較為優(yōu)雅的解決方案

 更新時間:2018年06月29日 09:57:36   作者:勇PAN高峰  
這篇文章主要介紹了詳解Vue微信授權(quán)登錄前后端分離較為優(yōu)雅的解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

微信授權(quán)登錄是一個非常常見的場景,利用微信授權(quán)登錄,我們可以很容易獲取用戶的一些信息,通過用戶對公眾號的唯一openid從而建立數(shù)據(jù)庫綁定用戶身份.

微信授權(quán)登錄的機制這里不做詳述,微信官方文檔已有詳述,簡述就是通過跳轉(zhuǎn)微信授權(quán)的頁面,用戶點擊確認后,微信會跳到回調(diào)頁面,此時回調(diào)頁面url上會攜帶code參數(shù),通過code參數(shù),后端可以拿code換取擁護openid,或者用戶信息

在vue項目中,通常是一個SPA應(yīng)用,即所有的頁面都是同一個html,通?,F(xiàn)在開發(fā)也是前后端徹底分離的,vue打包后生成的純靜態(tài)文件,甚至可以不經(jīng)過服務(wù)器,所以通過后端弄跳轉(zhuǎn)之類的都不太優(yōu)雅,本文即介紹此類場景的微信授權(quán)登錄

對于一個vue的SPA應(yīng)用,我們通??赡苡泻芏囗撁?在微信公眾號上我們可能配置多個菜單,多個菜單對應(yīng)vue的路由頁面,但是可能并不是每個頁面都需要用戶授權(quán)才能進入,有些頁面用戶不登錄也需要可以預(yù)覽,此時我們可以通過vue router來實現(xiàn)前端路由攔截

 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 {
   // 此狀態(tài)根據(jù)業(yè)務(wù)需求 可能不存在
   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為空,則跳轉(zhuǎn)到微信授權(quán)頁面
   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`
   }
  }
 }
})

上述代碼基本闡述了一個授權(quán)的過程,首先,我們在配置vue路由的時候,設(shè)置此路由是否需要登錄即給router的meta加一個noAuth:true的屬性,這個是處理不需要登錄的頁面,通過router.beforeEach進行判斷,如果是不需要登錄的頁面:noAuth,則直接next()讓其進入相應(yīng)頁面.對于需要登錄的頁面,則讓后端配合,此時,后端寫一個獲取用戶信息的接口,前端則直接調(diào)用獲取用戶信息的接口,當然,不需要每個頁面都調(diào)用,獲取一次之后可以將用戶信息存入vuex中,所以通過判斷vuex里面有沒有用戶信息,如果已存在用戶信息,則進入頁面.沒有用戶信息那就調(diào)用后端獲取用戶信息的接口,說到這里,終于回到此文主題了,用戶信息是通過微信授權(quán)登錄拿到的,此時后端如何拿到用戶信息呢?這里,可以跟后端商議好,用戶綁定身份后,后端則可以通過設(shè)置cookie,token之類的保存這個用戶登錄狀態(tài),如果有相關(guān)狀態(tài),那么后端則可以直接返回用戶信息. 如果是首次進入,或者cookie,token之類的已失效,那么此時則會調(diào)用微信授權(quán)登錄了,如上述代碼所述,分為三種情況,

1. 通過cookie,token等,后端直接拿到了用戶信息,此時則拿到用戶信息直接進入頁面,同時把用戶信息存入vuex中

2. 沒有用戶信息的情況,此時也沒有cookie,token,那就需要重新調(diào)用微信授權(quán)登錄了,上面給出的兩種返回碼code=201,code=202的情況,當code=2是則由前端直接跳轉(zhuǎn)到微信授權(quán)頁面,而redirectUri則為將要進入的頁面,此時會發(fā)生什么呢?會跳到微信授權(quán)頁面,用戶點擊之后又回到了這個頁面,不同的是此時url上面已經(jīng)攜帶了code,前端通過字符串截取拿到code,發(fā)送給后端,后端即可通過code換取openid以及用戶信息了.

總結(jié):

  1. 項目采用前后端完全分離方式,即打包后給的純靜態(tài)文件放在服務(wù)器,訪問index.html
  2. 后端不在接口處攔截,不需要后端跳轉(zhuǎn)微信授權(quán)登錄頁面,由前端路由來攔截跳轉(zhuǎn),實現(xiàn)方法如3.
  3. 前端在需要用戶身份才能進入的頁面通過vue-router的 router.beforeEach鉤子函數(shù)攔截,此時調(diào)用獲取用戶信息接口,后端首先通過獲取cookie,token等判斷用戶,無相關(guān)信息返回201或202,當返回202的時候,前端跳轉(zhuǎn)到微信授權(quán)頁,redirecturi即為要進入的頁面的url,跳轉(zhuǎn)授權(quán)后微信會在url上面攜帶code回到當前頁,此時前端截取url上的code傳給后端,后端通過code在后端處理拿到用戶信息,openid等實現(xiàn)了授權(quán)登錄  

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決Vue+Element ui開發(fā)中碰到的IE問題

    解決Vue+Element ui開發(fā)中碰到的IE問題

    今天小編就為大家分享一篇解決Vue+Element ui開發(fā)中碰到的IE問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue vite之LogicFlow安裝核心依賴及項目初始化詳解

    vue vite之LogicFlow安裝核心依賴及項目初始化詳解

    這篇文章主要為大家介紹了vue vite之LogicFlow安裝核心依賴及項目初始化詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • 基于Vue實現(xiàn)封裝一個虛擬列表組件

    基于Vue實現(xiàn)封裝一個虛擬列表組件

    正常情況下,我們對于數(shù)據(jù)都會分頁加載,最近項目中確實遇到了不能分頁的場景,如果不分頁,頁面渲染幾千條數(shù)據(jù)就會感知到卡頓,使用虛擬列表就勢在必行了。本文主要介紹了如何基于Vue實現(xiàn)封裝一個虛擬列表組件,感興趣的可以了解一下
    2023-03-03
  • vue3+ts使用APlayer的示例代碼

    vue3+ts使用APlayer的示例代碼

    這篇文章主要介紹了vue3+ts使用APlayer的示例代碼,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • vue封裝一個彈幕組件詳解

    vue封裝一個彈幕組件詳解

    這篇文章主要介紹了vue封裝一個彈幕組件詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙可以參考一下
    2022-08-08
  • js數(shù)組的 entries() 獲取迭代方法

    js數(shù)組的 entries() 獲取迭代方法

    這篇文章主要介紹了js數(shù)組的 entries() 獲取迭代方法,entries() 方法返回一個數(shù)組的迭代對象,該對象包含數(shù)組的鍵值對 (key/value)。下面來詳細介紹該neural,需要的朋友可以參考一下
    2021-10-10
  • 讓webpack+vue-cil項目不再自動打開瀏覽器的方法

    讓webpack+vue-cil項目不再自動打開瀏覽器的方法

    今天小編就為大家分享一篇讓webpack+vue-cil項目不再自動打開瀏覽器的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vite項目無法使用zangodb包裝器的解決方案

    vite項目無法使用zangodb包裝器的解決方案

    vite作為新一代工具鏈,具有很多便利之處,配置也非常簡單,它很好地整合了Rollup和其他復(fù)雜的構(gòu)建項,并提供了多種方向的典型腳手架模板,深受大家喜愛,本文給大家介紹了如何解決vite項目無法使用zangodb包裝器的問題,需要的朋友可以參考下
    2023-10-10
  • VUE3數(shù)據(jù)的偵聽超詳細講解

    VUE3數(shù)據(jù)的偵聽超詳細講解

    在Vue3中watch特性進行了一些改變和優(yōu)化,與computed不同,watch通常用于監(jiān)聽數(shù)據(jù)的變化,并執(zhí)行一些副作用,這篇文章主要給大家介紹了關(guān)于VUE3數(shù)據(jù)偵聽的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • vue 無法覆蓋vant的UI組件的樣式問題

    vue 無法覆蓋vant的UI組件的樣式問題

    這篇文章主要介紹了vue 無法覆蓋vant的UI組件的樣式問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論