前言
首先新建login组件,在路由模块中导入登录组件,并声明对应的路由规则
使用element组件实现登录功能
登录功能分析
- 点击登录按钮 发送登录的请求
- 把登录成功后的token记录到vuex中
- 持久化存储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: 有错误欢迎指出 里面还需要下载包哦哦~~