Vue项目 登录功能实现携带Token

893 阅读2分钟

前言

首先新建login组件,在路由模块中导入登录组件,并声明对应的路由规则

使用element组件实现登录功能

登录功能分析

  1. 点击登录按钮 发送登录的请求
  2. 把登录成功后的token记录到vuex中
  3. 持久化存储vuex中的数据 页面代码
  <template>
    <!-- 登录的盒子 -->
    <div class="login-box">
      <!-- 登录的表单区域 -->
      <el-form :model="loginForm" :rules="loginRules" ref="loginRef">
        <!-- 用户名 -->
        <el-form-item prop="username">
          <el-input v-model="loginForm.username" placeholder="请输入用户名" maxlength="10" minlength="1"></el-input>
        </el-form-item>
        <!-- 密码 -->
        <el-form-item prop="password">
          <el-input v-model="loginForm.password" type="password" placeholder="请输入密码"></el-input>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" class="btn-login" @click="login">登录</el-button>
        </el-form-item>
      </el-form>
  </div>
</template>

实现功能

<script>
export default {
  name: 'Login',
  data() {
    return {
      // 登录表单的数据对象
      loginForm: {
        username: '',
        password: ''
      },
      // 登录表单的验证规则对象
      loginRules: {
        username: [
          { required: true, message: '请输入用户名', trigger: 'blur' },
          { pattern: /^[a-zA-Z0-9]{1,10}$/, message: '用户名必须是1-10的字母数字', trigger: 'blur' }
        ],
        password: [
          { required: true, message: '请输入密码', trigger: 'blur' },
          { pattern: /^\S{6,15}$/, message: '密码必须是6-15的非空字符', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    // 实现登录功能
    login() {
      this.$refs.loginRef.validate(async valid => {
        if (!valid) return
        // 发起登录的请求
        const { data: res } = await this.$http.post('/api/login', this.loginForm)
        // 登录失败
        if (res.code !== 0) return this.$message.error(res.message)
        // 登录成功
        this.$message.success(res.message)
        // 将token存储到vuex
        this.$store.commit('updateToken', res.token)
        // 成功之后跳转首页
        this.$router.push('/')
      })
    }
  }
}
</script>

token项目开发中都会用到 属于全局共享的,需要持久化存储 可以借助vuex插件 大量存储 手动去存储 不智能

yarn add vuex-persistedstate

在store的index.js中配置

import Vue from 'vue'
import Vuex from 'vuex'
// 1. 导入包永久存储包
import createPersistedState from 'vuex-persistedstate'
Vue.use(Vuex)
export default new Vuex.Store({
// 2.使用vuex-persistedstate默认存储到localStorage
  plugins: [createPersistedState()],
  state: {
    token: ''
  },
  mutations: {
    updateToken(state, token) {
      state.token = token
    }
  },
  actions: {
  },
  modules: {
  }
})

后台管理系统获取用户信息都要携带token

每一次请求都需要携带token 可以放到请求拦截器

请求拦截器优化token携带

// 添加请求拦截器
axios.interceptors.request.use(function (config) {
// 只发送请求之前把token带上
  config.headers.Authorization = store.state.user.tokken
  return config
}, function (error) {
// 对请求错误做些什么
  return Promise.reject(error)
})

权限功能 -- 没有token

在路由index.js中

设置全局前置导航守卫

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

// 如果没有登录,就只能去登录或注册页,可以将登录页叫白名单

const whitList = ['/login','/reg']

// 如果没有登录 你去的页面不在白名单里面

if(!token&&!whitList .includes(to.path)){

return next ('/login')

})

token权限过期

响应拦截器 响应401 可以强行跳转登录页

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
// 对响应数据做点什么
    return response;
  }, function (error) {
// 对响应错误做点什么
if(error.response.status === 401){
// 清空token
store.commit('user/updateToken')
// 跳转至登录页
router.push('/login')
// 提醒用户
Vue.prototype.$message.error('您的身份验证过期')
}
   return Promise.reject(error);
  });

ps: 有错误欢迎指出 里面还需要下载包哦哦~~