<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        如何解決Vue微信授權登錄前后端分離的問題

        來源:懂視網 責編:小采 時間:2020-11-27 19:35:05
        文檔

        如何解決Vue微信授權登錄前后端分離的問題

        如何解決Vue微信授權登錄前后端分離的問題:這篇文章主要介紹了詳解Vue微信授權登錄前后端分離較為優雅的解決方案,內容挺不錯的,現在分享給大家,也給大家做個參考。微信授權登錄是一個非常常見的場景,利用微信授權登錄,我們可以很容易獲取用戶的一些信息,通過用戶對公眾號的唯一openid從而建立數據庫
        推薦度:
        導讀如何解決Vue微信授權登錄前后端分離的問題:這篇文章主要介紹了詳解Vue微信授權登錄前后端分離較為優雅的解決方案,內容挺不錯的,現在分享給大家,也給大家做個參考。微信授權登錄是一個非常常見的場景,利用微信授權登錄,我們可以很容易獲取用戶的一些信息,通過用戶對公眾號的唯一openid從而建立數據庫

        這篇文章主要介紹了詳解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以及用戶信息了.

        總結:

        1. 項目采用前后端完全分離方式,即打包后給的純靜態文件放在服務器,訪問index.html

        2. 后端不在接口處攔截,不需要后端跳轉微信授權登錄頁面,由前端路由來攔截跳轉,實現方法如3.

        3. 前端在需要用戶身份才能進入的頁面通過vue-router的 router.beforeEach鉤子函數攔截,此時調用獲取用戶信息接口,后端首先通過獲取cookie,token等判斷用戶,無相關信息返回201或202,當返回202的時候,前端跳轉到微信授權頁,redirecturi即為要進入的頁面的url,跳轉授權后微信會在url上面攜帶code回到當前頁,此時前端截取url上的code傳給后端,后端通過code在后端處理拿到用戶信息,openid等實現了授權登錄  

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        如何解決Vue微信授權登錄前后端分離的問題

        如何解決Vue微信授權登錄前后端分離的問題:這篇文章主要介紹了詳解Vue微信授權登錄前后端分離較為優雅的解決方案,內容挺不錯的,現在分享給大家,也給大家做個參考。微信授權登錄是一個非常常見的場景,利用微信授權登錄,我們可以很容易獲取用戶的一些信息,通過用戶對公眾號的唯一openid從而建立數據庫
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲av不卡一区二区三区| 亚洲天堂中文字幕在线| 亚洲成人黄色在线| 中文字幕免费高清视频| 亚洲狠狠ady亚洲精品大秀| 久久午夜伦鲁片免费无码| 亚洲高清无在码在线无弹窗| 免费观看黄色的网站| 亚洲国产精品综合久久20| 免费无码不卡视频在线观看| 亚洲日韩精品无码专区加勒比| 四虎成人免费影院网址| 免费福利资源站在线视频| 国外亚洲成AV人片在线观看 | 亚洲色成人WWW永久网站| baoyu777永久免费视频| 亚洲国产高清视频| 久久久久久久免费视频| 亚洲精品色播一区二区| 免费人成网站在线高清| 女同免费毛片在线播放| 亚洲精品视频在线观看免费| 成人免费无码大片A毛片抽搐 | 亚洲av日韩av欧v在线天堂| 亚洲精品黄色视频在线观看免费资源| 在线日韩日本国产亚洲| 久久久久久精品免费免费自慰| 亚洲人AV在线无码影院观看| 中文字幕亚洲一区二区va在线| 午夜精品一区二区三区免费视频| 亚洲sss综合天堂久久久| 亚洲日韩VA无码中文字幕 | 亚洲精品亚洲人成在线观看| 51在线视频免费观看视频| 亚洲欧美成人av在线观看 | 亚洲欧洲日本在线观看| 免费国产不卡午夜福在线| 国产精品区免费视频| 亚洲精品亚洲人成在线| 九月丁香婷婷亚洲综合色| 成人免费无码大片A毛片抽搐|