亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue實現(xiàn)token登錄驗證的完整實例

 更新時間:2022年04月22日 16:17:55   作者:懶啦  
最近公司新啟動了個項目,用的是vue框架在做,下面這篇文章主要給大家介紹了關于vue實現(xiàn)token登錄驗證的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

token可用于登錄驗證和權限管理。

大致步驟分為:

  1. 前端登錄,post用戶名和密碼到后端。
  2. 后端驗證用戶名和密碼,若通過,生成一個token返回給前端。
  3. 前端拿到token存儲到localStorage管理,登錄成功進入首頁。
  4. 之后前端每一次權限操作如跳轉路由,都需要判斷是否存在token,若不存在,跳轉至登錄頁。
  5. 前端之后的每一個對后端的請求都要在請求頭上帶上token,后端查看請求頭是否有token,拿到token檢查是否過期,返回對應狀態(tài)給前端。
  6. 若token已過期,清除token信息,跳轉至登錄頁。

登錄頁 -----Login.vue

<template>
  <!-- 登錄 -->
  <div>
    <el-container>
      <el-main>
        <div class="box">
          <el-form
            :model="user"
            :rules="rules"
            ref="user"
            label-width="100px"
            class="demo-ruleForm"
          >
            <el-form-item label="用戶名" prop="email">
              <el-input v-model="user.email"></el-input>
            </el-form-item>
            <el-form-item label="密碼" prop="pass">
              <el-input type="password" v-model="user.password"></el-input>
            </el-form-item>
            <el-form-item>
              <el-button type="primary" @click="login">登錄</el-button>
            </el-form-item>
          </el-form>
        </div>
      </el-main>
    </el-container>
  </div>
</template>

<script>
import {LoginPostData} from '../../api/index'  // 后端登錄接口
export default {
  data() {
    return {
      rules: {
        email: [
          { required: true, message: "請輸入用戶名", trigger: "blur" },
          { min: 3, max: 20, message: "長度在 3 到 20 個字符", trigger: "blur" },
        ],
        password: [
          { required: true, message: "請輸入密碼", trigger: "blur" },
          { min: 3, max: 5, message: "長度在 3 到 5 個字符", trigger: "blur" },
        ],
      },
      user:{
        email:'',
        password:''
      },
      userToken:'', // 用于存儲從后臺獲取的token
    };
  },
  methods:{
      login(){
      // 登錄接口
      LoginPostData(this.user.email,this.user.password)
      .then((res)=>{ 
      // 將token存到userToken中     
        this.userToken = res.data.data.token
        // 將token本地存儲到回話中
        localStorage.setItem('token', this.userToken);
        // 如果code為200則跳轉到NewReport頁面
        if(res.data.code === 200){
        this.$router.push({name:'NewReport'})
        this.$message({
          message: '恭喜你,登錄成功',
          type: 'success'
        });
        }else{
          this.$message.error(res.data.data);
        }
      })
      .catch(err=>{
        console.log(err);
      })
      }
  },
};
</script>

路由守衛(wèi) ----- router/index.js

import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)
const routes = [
  // 登錄頁
  {
    path: '/',
    name: 'Login',
    component: ()=>import('../views/Login/Login.vue'),
  },
  // 首頁
  {
    path: '/Home',
    name: 'Home',
    component: ()=>import('../views/Home/Home.vue'),
    children:[
      // 新建報表
      {
        path:'/Home/NewReport',
        name:'NewReport',
        component:()=>import('../views/Home/NewReport.vue')
      },
    ]
  },
]

const router = new VueRouter({
  routes
})

// 導航守衛(wèi)
// 使用 router.beforeEach 注冊一個全局前置守衛(wèi),判斷用戶是否登陸
router.beforeEach((to, from, next) => {
//如果去往登錄頁則放行 
  if (to.path === '/') {
    next();
  } else {
    // 從本地存儲里獲取token
    let token = localStorage.getItem('token');
    // 判斷token是否為空如果為空則跳轉到登錄頁 如果有則放行
    if (token === null || token === '') {
      next({path:'/'});
    } else {
      next();
    }
  }
});

export default router

封裝axios 添加請求攔截器 在每次請求之前進行的操作

在請求頭中添加token ---- api/request.js

// 請求
import axios from 'axios'

// create an axios instance   創(chuàng)建axios實例
const instance = axios.create({
	baseURL: 'http://192.168.3.6:8082', // api 的 base_url
	withCredentials: false//跨域時使用憑證,默認帶上cookies
	// timeout: 2000, // request timeout  設置請求超時時間
  })

// 添加請求攔截器,在請求頭中加token
instance.interceptors.request.use(
  config => {
  //判斷token是否存在
    if (localStorage.getItem('token')) {
    // 在請求頭中添加token
      config.headers.token = localStorage.getItem('token');
    }
    return config;
  },
  error => {
    return Promise.reject(error);
  });

export default instance

注意:

鬼知道我當時為了這個找了多半天 哭死

home頁面

<template>
  <div>
    <el-link icon="el-icon-switch-button" @click="tuichu">退出登錄</el-link>
  </div>
</template>

<script>
export default {
    methods: {
    // 退出
    tuichu() {
      //退出登錄,清空token
      localStorage.removeItem('token');
      this.$router.push({ name: "Login" });
    },
  },
};
</script>

總結

到此這篇關于vue實現(xiàn)token登錄驗證的文章就介紹到這了,更多相關vue token登錄驗證內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vite+vue3搭建的工程熱更新失效問題及解決

    vite+vue3搭建的工程熱更新失效問題及解決

    這篇文章主要介紹了vite+vue3搭建的工程熱更新失效問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3.0-props、computed、自定義事件方式

    vue3.0-props、computed、自定義事件方式

    這篇文章主要介紹了vue3.0-props、computed、自定義事件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue使用highcharts自定義圖例點擊事件

    vue使用highcharts自定義圖例點擊事件

    這篇文章主要為大家詳細介紹了vue使用highcharts自定義圖例點擊事件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 談談Vue.js——vue-resource全攻略

    談談Vue.js——vue-resource全攻略

    本篇文章主要介紹了談談Vue.js——vue-resource全攻略,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • Vue進階之利用transition標簽實現(xiàn)頁面跳轉動畫

    Vue進階之利用transition標簽實現(xiàn)頁面跳轉動畫

    這篇文章主要為大家詳細介紹了Vue如何利用transition標簽實現(xiàn)頁面跳轉動畫,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起一下
    2023-08-08
  • VUE實現(xiàn)吸底按鈕

    VUE實現(xiàn)吸底按鈕

    這篇文章主要為大家詳細介紹了VUE實現(xiàn)吸底按鈕,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • VUE3+mqtt封裝解決多頁面使用需重復連接等問題(附實例)

    VUE3+mqtt封裝解決多頁面使用需重復連接等問題(附實例)

    最近了解到mqtt這樣一個協(xié)議,可以在web上達到即時通訊的效果,下面這篇文章主要給大家介紹了關于VUE3+mqtt封裝解決多頁面使用需重復連接等問題的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-04-04
  • 基于Vue實現(xiàn)可選擇不連續(xù)的時間范圍的日期選擇器

    基于Vue實現(xiàn)可選擇不連續(xù)的時間范圍的日期選擇器

    這篇文章主要為大家詳細介紹了如何基于Vue.js實現(xiàn)一個可選擇不連續(xù)的時間范圍的日期選擇器,文中的示例代碼簡潔易懂,需要的可以參考一下
    2023-06-06
  • 詳解用vue2.x版本+adminLTE開源框架搭建后臺應用模版

    詳解用vue2.x版本+adminLTE開源框架搭建后臺應用模版

    這篇文章主要介紹了用vue2.x版本+adminLTE開源框架 搭建后臺應用模版,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • vue中axios封裝使用的完整教程

    vue中axios封裝使用的完整教程

    這篇文章主要給大家介紹了關于vue中axios封裝使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03

最新評論