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

溫馨提示×

溫馨提示×

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

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

vue中微信授權登錄的示例分析

發布時間:2021-07-20 13:47:00 來源:億速云 閱讀:114 作者:小新 欄目:web開發

這篇文章主要介紹了vue中微信授權登錄的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

背景

vue前后端分離開發微信授權

場景

app將商品分享到微信朋友圈或者分享給微信好友,用戶點擊頁面時進行微信授權登陸,獲取用戶信息。

問題:沒有固定的h6應用首頁。授權后重定向url帶參數并且很長

本人愚鈍,開發過程中,嘗試過很多方法,踩坑不足以形容我的心情,可以說每一次都是一次跳井的體驗啊。

1.一開始是前端請求微信連接,返回code,然后code作為再去請求后臺接口獲取token,后面看到別人的博客說這個方法不好,最好就是直接請求后臺接口,然后后臺返回url做跳轉,所以就采用了最傳統的方法,后臺返回url,前臺跳轉。

async ReturnGetCodeUrl() {
  let {
    data
  } = await getWxAuth({});
  if (data.status == 200) {
    window.location.href = data.url;

    // 返回的結果
    // redirect_uri重定向的url是后臺的地址,后臺就是可拿到code,獲取token
    // https://open.weixin.qq.com/connect/oauth3/authorizeappid=xxxxxxxxxxxxxxxxxx&redirect_uri=***url***&response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirect
    
  }
 },

2.這個時候就出現一個問題,微信授權要跳跳跳,最終想回到第一次點進來時候的鏈接就蛋疼了,從網上查了一下解決方法,將鏈接本身作為redirect_uri參數,大概就是這個樣子

https://open.weixin.qq.com/connect/oauth3/authorizeappid=xxxxxxxxxxxxxxxxxx&redirect_uri=*www.admin?http://www.xxx.com/h6/product*&response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirect

然而我們的前臺鏈接是這個鬼樣子的,本身帶參數,而且超長,what?微信可能不會接受我長這么丑。/(ㄒoㄒ)/~~

http://www.xxx.com/h6/product?id=6RedfM5O4xeyl0AmOwmyipkHr8AQCv-hYXZVAIFTwDXOsWSKqgu3VaCmaKSerBnacvWuzO3Zwdf8y%2F2K2lvqkluV6Ane4LCAKyPU2tPAPj%2FMF6F6xkzp27GqqpNya7HbdEA34qGQJvHIA9tlIMkeEWid1112b8oZuP3FQBwU%2F%2FMaSrovzQP6LlzWamyPnv0vMizu8uh0ItpJOQUV1m%2FtemF3U9KuHo8rXCw%3D

最終放棄了這個方案

3.考慮如何重定向我的前臺地址,并且獲取token

接下來就是我現在用的方法,bug還有很多,先分享一下我的方法,后期優化或有更好的方法再做修改
在main.js中路由全局鉤子判斷本地是不是有user_token,也就是微信授權后返回的token,如果沒有token,并且當前的路由不是author(專門為了授權而生的頁面),那就保存當前的url,比如www.xxx.com/h6/product?id=6RedfM5O4xeyl0AmOwm,然后進入author。那如果本地有token,就是用戶之前授權拿到過token并且vuex里沒有用戶信息,那我就獲取用戶信息并保存在vuex中,這里遇到一個問題就是token會出現過期的情況,那我就刪除了本地的user_token,window.localStorage.removeItem("user_token");刷新頁面 router.go(0);這個時候就重新走了一遍如果沒有token的情況。

 router.beforeEach((to, from, next) => {
   //  第一次進入項目
   let token = window.localStorage.getItem("user_token");
   
   if (!token && to.path != "/author") {
    window.localStorage.setItem("beforeLoginUrl", to.fullPath); // 保存用戶進入的url
    next("/author");
    return false;
   } else if (token && !store.getters.userInfo) {
   //獲取用戶信息接口
    store
     .dispatch("GetUserInfo", {
      user_token: token
     })
     .catch(err => {
      window.localStorage.removeItem("user_token");
      router.go(0);
      return false;
     });
   }
   next();
  });

下面就是進入author.vue的邏輯,第一次進入author, www.xxxx.com/h6/author,判斷鏈接有沒有token參數,如果沒有就跳微信授權,然后后臺會重定向回來并攜帶token,如: www.xxxx.com/h6/author?token=xxxxxxxxx&msg=200

<template>
  <div>
授權中。。。
  </div>
</template>

<script>
 
  import {
   getWxAuth
  } from '@/service/getData'
  import {
   GetQueryString 
  } from '@/utils/mixin';
  export default {
   data() {
     return {
      token: '',
     };
   },
   computed: {
    
   },
   created() {
     this.token = window.localStorage.getItem("user_token");
     //判斷當前的url有沒有token參數,如果不存在那就跳轉到微信授權的url
     //就是前面說的ReturnGetCodeUrl方法
 
     if (!GetQueryString("token")) {
      this.ReturnGetCodeUrl();
     } else {
      //如果有token,如http://www.xxxx.com/h6/author?token=xxxxxxxxx&msg=200,這里的參數就是后臺重定向到前臺http://www.xxxx.com/h6/author,并攜帶的參數。這樣就可以拿到我們想要的token了
      //判斷一下后臺返回的狀態碼msg,因為可能出現微信拿不到token的情況
      let msg = GetQueryString("msg")
      if (msg = 200) {
        this.token = GetQueryString("token");
        //存儲token到本地
        window.localStorage.setItem("user_token", this.token);
        //獲取beforeLoginUrl,我們的前端頁面
        let url = window.localStorage.getItem("beforeLoginUrl");
        //跳轉
        this.$router.push(url);
        //刪除本地beforeLoginUrl
        removeLocalStorage("beforeLoginUrl");
      }else{
      //msg不是200的情況,可能跳到404的錯誤頁面
      }
     }
   },
   methods: {
    
     async ReturnGetCodeUrl() {
      let {
        data
      } = await getWxAuth({});
      if (data.status == 200) {
       
        window.location.href = data.url;
      }
     },

     
   },
   watch: {},

   components: {},


   mounted: function () {}
  }
</script>
<style lang='scss' scoped>

</style>

GetQueryString方法

mixin.js

export const GetQueryString = name => {
 var url = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
 var newUrl = window.location.search.substr(1).match(url);
 if (newUrl != null) {
  return unescape(newUrl[2]);
 } else {
  return false;
 }
};

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vue中微信授權登錄的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

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

vue
AI

措勤县| 北流市| 金秀| 安康市| 杨浦区| 郯城县| 天全县| 仁寿县| 原阳县| 瑞安市| 西乌珠穆沁旗| 九龙县| 邓州市| 珲春市| 高清| 天台县| 淳化县| 广德县| 江城| 丁青县| 海兴县| 常熟市| 偃师市| 尼玛县| 香河县| 三河市| 千阳县| 新平| 朝阳区| 土默特左旗| 永寿县| 永康市| 太白县| 竹山县| 仁怀市| 松原市| 手游| 长海县| 东辽县| 祁门县| 宁德市|