Vue登錄注冊,並保持登錄狀態


關於vue登錄注冊,並保持登錄狀態,是vue玩家必經之路,網上也有很多的解決方法,但是有一些太過於復雜,新手可能會看的一臉懵逼,現在給大家介紹一種我自己寫項目在用而且並不難理解的一種方法。

項目中有一些路由是需要登錄才可以進入的,比如首頁,個人中心等等
有一些路由是不需要登錄就可以進入,比如登錄頁,注冊頁,忘記密碼等等
那如何判斷路由是否需要登錄呢?就要在路由JS里面做文章

在router.js中添加meta區分

比如登錄注冊頁面,不需要登錄即可進入,那么我們把meta中的isLogin標志設置為false

{
  //登錄
  path: '/login',
  component: login,
  meta: {
    isLogin: false
  }
},
{
  //注冊
  path: '/register',
  component: register,
  meta: {
    isLogin: false
  }
},

而在首頁我們需要登錄才能進入,那么我們把meta中的isLogin標志設置為true

{
  //首頁
  path: '/home',
  component: home,
  meta: {
    isLogin: true
  },
}

這樣我們就為進入各個路由是否需要登錄做了區分。

 

接下來我們在login.vue中修改登錄后狀態

我們使用axios向后台發起登錄請求

this.$axios.post("/xxx/login", {user:name,password:pwd})
    .then(data => {
        //登錄失敗,先不討論
        if (data.data.status != 200) {
          //iViewUi的友好提示
          this.$Message.error(data.data.message);
        //登錄成功
        } else {
          //設置Vuex登錄標志為true,默認userLogin為false
          this.$store.dispatch("userLogin", true);
          //Vuex在用戶刷新的時候userLogin會回到默認值false,所以我們需要用到HTML5儲存
          //我們設置一個名為Flag,值為isLogin的字段,作用是如果Flag有值且為isLogin的時候,證明用戶已經登錄了。
          localStorage.setItem("Flag", "isLogin");
          //iViewUi的友好提示
          this.$Message.success(data.data.message);
          //登錄成功后跳轉到指定頁面
          this.$router.push("/home");
        }
 });

Vuex里面我是這樣寫的(如果項目不需要Vuex,那么直接使用HTML5儲存就可以了):

export const store = new Vuex.Store({
  // 設置屬性
  state: {
    isLogin: false,
  },

  // 獲取屬性的狀態
  getters: {
    //獲取登錄狀態
    isLogin: state => state.isLogin,
  },

  // 設置屬性狀態
  mutations: {
    //保存登錄狀態
    userStatus(state, flag) {
      state.isLogin = flag
    },
  },

  // 應用mutations
  actions: {
    //獲取登錄狀態
    userLogin({commit}, flag) {
      commit("userStatus", flag)
    },
  }
})

重點來了~,在mian.js里

router.beforeEach((to, from, next) => {

  //獲取用戶登錄成功后儲存的登錄標志
  let getFlag = localStorage.getItem("Flag");

  //如果登錄標志存在且為isLogin,即用戶已登錄
  if(getFlag === "isLogin"){

    //設置vuex登錄狀態為已登錄
    store.state.isLogin = true
    next()

    //如果已登錄,還想想進入登錄注冊界面,則定向回首頁
    if (!to.meta.isLogin) {
       //iViewUi友好提示
      iView.Message.error('請先退出登錄')
      next({
        path: '/home'
      })
    }
  
  //如果登錄標志不存在,即未登錄
  }else{

    //用戶想進入需要登錄的頁面,則定向回登錄界面
    if(to.meta.isLogin){
      next({
        path: '/login',
      })
      //iViewUi友好提示
      iView.Message.info('請先登錄')
    //用戶進入無需登錄的界面,則跳轉繼續
    }else{
      next()
    }

  }

});

router.afterEach(route => {
  window.scroll(0, 0);
});

這樣就已經完成了Vue的登錄注冊,當用戶關閉瀏覽器或者第二天再次進入網站,用戶依舊可以保持着登錄的狀態直到用戶手動退出登錄。

Tips:用戶退出只需要localStorage.removeItem("Flag")即可

 

參考---https://segmentfault.com/a/1190000016040068


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM