VUE 基于axios vuex 前后分離token驗(yàn)證

一礁凡、vuex

一般的高氮,用戶登錄后會(huì)在本地持久化存儲(chǔ)用戶的認(rèn)證信息,本文以JWT的token為例顷牌。將用戶的token持久化到localStorage里剪芍,而用戶信息則存在內(nèi)存(store)中。

state: {
  token: "",
  userName: ""
},
mutations: {
  set_token(state, token) {
    state.token = "JWT " + token;
    localStorage.setItem("token", token);
  },
  del_token(state) {
    state.token = "";
    localStorage.removeItem("token");
  },
  setUserInfo(state, userName) {
    state.userName = userName;
  }
},
});

二韧掩、登錄成功時(shí)將token持久化到localStorage

          this.$axios
            .post("/api/users/login", this.form)
            .then(res => {
              res = res.data;
              if (res.code == 0) {
                this.isLogin = true;
                this.$store.commit("set_token", res.data.token);
                this.$store.commit("setUserInfo", res.data.username);
                if (this.$store.state.token) {
                  this.$router.push("/");
                } else {
                  this.$router.replace("/login");
                }
              }

三紊浩、main.js中的axios

axios.interceptors.request.use(
config => {
  //在所有請求頭部添加token值
  const token = store.state.token;
  if (token) {
    config.headers.Authorization = token;
  }
  return config;
},
error => {
  console.log("err");
  return Promise.reject(error);
}
);
// response 攔截器
axios.interceptors.response.use(
response => {
  return response;
},
error => {
  if (error.response) {
    switch (error.response.status) {
      case 401:
        this.$store.commit("del_token");
        router.replace({
          path: "/login",
          query: { redirect: router.currentRoute.fullPath } //登錄成功后跳入瀏覽的當(dāng)前頁面
        });
    }
  }
  return Promise.reject(error.response.data);
}
);

四、router.js權(quán)限路由配置

某些頁面規(guī)定必須登錄后才能查看 疗锐,可以再router中配置meta坊谁,將需要登錄的requireAuth設(shè)為true,

    {
      path: "/",
      name: "home",
      component: () => import("./views/Home.vue"),
      meta: {
        requireAuth: true,
      }
    },
    {
      path: "/login",
      name: "login",
      component: () => import("./views/login/login.vue"),
    },

然后設(shè)置路由守衛(wèi)滑臊,在進(jìn)頁面之前口芍,判斷有token,才進(jìn)入頁面雇卷,否則返回登錄頁面鬓椭。


if (localStorage.getItem("token")) {
store.commit("set_token", localStorage.getItem("token"));
}
router.beforeEach((to, from, next) => {
if (to.matched.some(r => r.meta.requireAuth)) {
  if (store.state.token) {
    next();
  } else {
    next({
      path: "/login"
    });
  }
} else {
  next();
}
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市关划,隨后出現(xiàn)的幾起案子小染,更是在濱河造成了極大的恐慌,老刑警劉巖贮折,帶你破解...
    沈念sama閱讀 210,835評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件裤翩,死亡現(xiàn)場離奇詭異,居然都是意外死亡调榄,警方通過查閱死者的電腦和手機(jī)踊赠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,900評論 2 383
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來每庆,“玉大人筐带,你說我怎么就攤上這事$土椋” “怎么了伦籍?”我有些...
    開封第一講書人閱讀 156,481評論 0 345
  • 文/不壞的土叔 我叫張陵蓝晒,是天一觀的道長。 經(jīng)常有香客問我鸽斟,道長拔创,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,303評論 1 282
  • 正文 為了忘掉前任富蓄,我火速辦了婚禮剩燥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘立倍。我一直安慰自己灭红,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,375評論 5 384
  • 文/花漫 我一把揭開白布口注。 她就那樣靜靜地躺著变擒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪寝志。 梳的紋絲不亂的頭發(fā)上娇斑,一...
    開封第一講書人閱讀 49,729評論 1 289
  • 那天,我揣著相機(jī)與錄音材部,去河邊找鬼毫缆。 笑死,一個(gè)胖子當(dāng)著我的面吹牛乐导,可吹牛的內(nèi)容都是我干的苦丁。 我是一名探鬼主播,決...
    沈念sama閱讀 38,877評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼物臂,長吁一口氣:“原來是場噩夢啊……” “哼旺拉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起棵磷,我...
    開封第一講書人閱讀 37,633評論 0 266
  • 序言:老撾萬榮一對情侶失蹤蛾狗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后仪媒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體淘太,經(jīng)...
    沈念sama閱讀 44,088評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,443評論 2 326
  • 正文 我和宋清朗相戀三年规丽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片撇贺。...
    茶點(diǎn)故事閱讀 38,563評論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赌莺,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出松嘶,到底是詐尸還是另有隱情艘狭,我是刑警寧澤,帶...
    沈念sama閱讀 34,251評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站巢音,受9級特大地震影響遵倦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜官撼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,827評論 3 312
  • 文/蒙蒙 一梧躺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧傲绣,春花似錦掠哥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,712評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至菠净,卻和暖如春禁舷,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背毅往。 一陣腳步聲響...
    開封第一講書人閱讀 31,943評論 1 264
  • 我被黑心中介騙來泰國打工牵咙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人煞抬。 一個(gè)月前我還...
    沈念sama閱讀 46,240評論 2 360
  • 正文 我出身青樓霜大,卻偏偏與公主長得像,于是被迫代替她去往敵國和親革答。 傳聞我的和親對象是個(gè)殘疾皇子战坤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,435評論 2 348