Vue3+Element-Plus 登录功能实现成功后的行为 十六
1.登录成功之后的行为1.1 如何将登录成功后服务器分配给用户的token 保存在客户端中① 为什么要保存token?项目中除了登录之外的其他API接口,必须在登录之后才能访问② 如果访问了其他接口,如何告诉该接口,当前已经是登录过了?访问该接口的时候,可以告诉它token。因为token是用户登录之后,服务器发给用户访问服务器资源的令牌或者是身份认证的信息在访问该接口时,携带着用户自己的toke
1.登录成功之后的行为
1.1 如何将登录成功后服务器分配给用户的token 保存在客户端中
① 为什么要保存token?
- 项目中除了登录之外的其他API接口,必须在登录之后才能访问
② 如果访问了其他接口,如何告诉该接口,当前已经是登录过了?
- 访问该接口的时候,可以告诉它token。因为token是用户登录之后,服务器发给用户访问服务器资源的令牌或者是身份认证的信息
- 在访问该接口时,携带着用户自己的token.那么一定是可以成功访问服务器资源的。
③ token 保存在客户端的两种方式 localStorage和sessionStorage
- localStorage 是持久化存储机制
- sessionStorage 是会话期间的存储机制
④ 我们选择使用sessionStorage,因为我们希望这个token只应在当前网站打开期间生效
1.2 如何保存token
① 首先我们打印一下登录成功后返回的信息,查看一下token信息
② 通过window.sessionStorage.setItem 来保存token
如下图,这个值的获取
1.3 通过编程式导航跳转到后台主页,路由地址是 /home
① 接下来,通过this.$router.push()进行后台页面跳转
② 如何查看登录后token,F12 检查元素,添加
③ 找到应用程序
④ 会话存储,就是保存用户登录的token
⑤ 如图,登录成功后,token就保存在了sessionStorage中
⑥ 同时,登录成功后,我们通过编程式导航,也发生了一次页面跳转
1.4 创建home页面和完善路由规则
① 在components新建一个Home.vue页面
② 在路由规则组件中,导入Home组件并添加路由规则
③ 效果
1.5 代码
router/index.js 路由规则代码
import { createRouter, createWebHashHistory } from 'vue-router'
import Login from '../components/Login.vue'
import Home from '../components/Home.vue'
const routes = [
{
path: '/',
redirect: '/login'
},
{
path: '/login',
component: Login
},
{
path: '/home',
component: Home
}
]
const router = createRouter({
history: createWebHashHistory(),
routes
})
export default router
Login.vue
<template>
<div class="login_container">
<div class="login_box">
<!-- 头像区域 -->
<div class="avatar_box">
<img src="../assets/logo.png" alt="" />
</div>
<!-- 登录表单区域 -->
<el-form ref="loginFormRef" :model="loginForm" :rules="loginFormRules" label-width="0px" class="login_form">
<!-- 用户名 -->
<el-form-item prop="username">
<el-input
v-model="loginForm.username"
prefix-icon="iconfont icon-yonghu"
>
</el-input>
</el-form-item>
<!-- 密码 -->
<el-form-item prop="password">
<el-input
v-model="loginForm.password" type="password"
prefix-icon="iconfont icon-mima"
>
</el-input>
</el-form-item>
<!-- 按钮区域 -->
<el-row justify="end">
<el-form-item class="login_btn">
<el-button type="primary" @click="Login">登录</el-button>
<el-button type="info" @click="resetLoginForm">重置</el-button>
</el-form-item>
</el-row>
</el-form>
</div>
</div>
</template>
<script>
export default {
data () {
return {
// 这是登录表单的数据绑定对象
loginForm: {
username: '',
password: ''
},
// 这是表单的验证规则对象
loginFormRules: {
// 验证用户名是否合法
username: [
{ required: true, message: '请输入登录名称', trigger: 'blur' },
{ min: 2, max: 10, message: '长度在 2 到 10 个字符', trigger: 'blur' }
],
// 验证密码是否合法
password: [
{ required: true, message: '请输入登录密码', trigger: 'blur' },
{ min: 6, max: 15, message: '长度在 6 到 15 个字符', trigger: 'blur' }
]
}
}
},
methods: {
resetLoginForm () {
this.$refs.loginFormRef.resetFields()
},
Login () {
this.$refs.loginFormRef.validate(async valid => {
if (!valid) return
const { data: result } = await this.$http.post('login', this.loginForm)
if (result.meta.status !== 200) return this.$message.error('登录失败')
this.$message.success('登录成功')
console.log(result.data.token)
window.sessionStorage.setItem('token', result.data.token)
this.$router.push('/home')
})
}
}
}
</script>
<style lang="less" scoped>
.login_container {
background-color: #2b4b6b;
height: 100vh;
}
.login_box {
// 宽450像素
width: 450px;
// 高300像素
height: 300px;
// 背景颜色
background-color: #fff;
// 圆角边框3像素
border-radius: 3px;
// 绝对定位
position: absolute;
// 距离左则50%
left: 50%;
// 上面距离50%
top: 50%;
// 进行位移,并且在横轴上位移-50%,纵轴也位移-50%
transform: translate(-50%, -50%);
.avatar_box {
// 盒子高度130像素
height: 130px;
// 宽度130像素
width: 130px;
// 边框线1像素 实线
border: 1px solid #eee;
// 圆角
border-radius: 50%;
// 内padding
padding: 10px;
// 添加阴影 向外扩散10像素 颜色ddd
box-shadow: 0 0 10px #ddd;
// 绝对定位
position: absolute;
// 距离左则
left: 50%;
// 位移
transform: translate(-50%, -50%);
// 背景
background-color: #fff;
img {
width: 100%;
height: 100%;
border-radius: 50%;
background-color: #eee;
}
}
}
.login_form {
position: absolute;
bottom: 0;
width: 100%;
padding: 0 20px;
box-sizing: border-box;
}
.login_btn {
// 设置弹性布局
display: flex;
// 横轴上尾部对齐
justify-content: flex-end;
}
</style>
以上出自于:【黑马程序员】前端开发之Vue项目实战_Element-UI【配套源码+笔记】_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1x64y1S7S7?p=1
更多推荐
所有评论(0)