当前位置: 首页 > news >正文

网站网站怎么做微网站哪家好

网站网站怎么做,微网站哪家好,建设部网站在哪里报名考试,在阿里巴巴做网站多少钱2019在Vue 3中,导航守卫(Navigation Guard)用于拦截路由的变化,可以在用户访问页面前进行检查。结合Axios进行token认证机制时,我们可以通过导航守卫在路由跳转时,检查用户的认证状态,确保用户有有效…

在Vue 3中,导航守卫(Navigation Guard)用于拦截路由的变化,可以在用户访问页面前进行检查。结合Axios进行token认证机制时,我们可以通过导航守卫在路由跳转时,检查用户的认证状态,确保用户有有效的token进行认证。

下面,我将通过具体代码示例,逐步讲解如何实现这一功能:

文章目录

      • 1. 安装必要的依赖
      • 2. 创建 `axios` 实例
      • 3. 在 `router.js` 中使用导航守卫
      • 4. 处理登录与登出逻辑
      • 5. 使用场景
      • 6. 总结

1. 安装必要的依赖

首先,确保你已经安装了 axios,这是我们用来发起 HTTP 请求的库。

npm install axios

2. 创建 axios 实例

我们通常会创建一个封装了token认证逻辑的 axios 实例,便于管理所有请求。

// src/utils/axios.js
import axios from 'axios';const instance = axios.create({baseURL: 'https://api.example.com', // 设置基本的 API 地址timeout: 5000, // 设置请求超时
});// 请求拦截器
instance.interceptors.request.use(config => {const token = localStorage.getItem('token'); // 从localStorage获取tokenif (token) {config.headers['Authorization'] = `Bearer ${token}`; // 在请求头中加入token}return config;
}, error => {return Promise.reject(error);
});// 响应拦截器
instance.interceptors.response.use(response => {return response;
}, error => {if (error.response.status === 401) {// 如果响应返回 401,表示未授权,可以跳转到登录页面window.location.href = '/login';}return Promise.reject(error);
});export default instance;

3. 在 router.js 中使用导航守卫

接下来,在 router.js 中配置路由的导航守卫,检查每次路由跳转前的用户认证状态。

// src/router/index.js
import { createRouter, createWebHistory } from 'vue-router';
import axios from '../utils/axios'; // 导入axios实例
import Home from '../views/Home.vue';
import Login from '../views/Login.vue';const routes = [{path: '/',name: 'Home',component: Home,meta: { requiresAuth: true }, // 需要认证的页面},{path: '/login',name: 'Login',component: Login,},
];const router = createRouter({history: createWebHistory(process.env.BASE_URL),routes,
});// 全局前置守卫
router.beforeEach(async (to, from, next) => {const token = localStorage.getItem('token');if (to.meta.requiresAuth) {if (!token) {// 如果目标路由需要认证且没有token,跳转到登录页return next({ name: 'Login' });}try {// 如果有token,验证token是否有效const response = await axios.get('/verify-token'); // 假设后端提供了验证token的接口if (response.status === 200) {next(); // token有效,允许继续访问}} catch (error) {// token无效或请求失败,跳转到登录页localStorage.removeItem('token'); // 清除无效tokennext({ name: 'Login' });}} else {next(); // 不需要认证的页面,直接访问}
});export default router;

4. 处理登录与登出逻辑

在用户登录时,我们会获取token并将其存储在 localStorage 中;登出时,我们需要清除token。

// src/views/Login.vue
<template><div><h1>Login</h1><form @submit.prevent="handleLogin"><input v-model="username" placeholder="Username" /><input v-model="password" type="password" placeholder="Password" /><button type="submit">Login</button></form></div>
</template><script>
import axios from '../utils/axios';export default {data() {return {username: '',password: '',};},methods: {async handleLogin() {try {const response = await axios.post('/login', {username: this.username,password: this.password,});const token = response.data.token;localStorage.setItem('token', token); // 保存tokenthis.$router.push('/'); // 登录成功后跳转到首页} catch (error) {console.error('Login failed:', error);}},},
};
</script>
// src/views/Home.vue
<template><div><h1>Welcome Home</h1><button @click="handleLogout">Logout</button></div>
</template><script>
export default {methods: {handleLogout() {localStorage.removeItem('token'); // 清除tokenthis.$router.push('/login'); // 跳转到登录页},},
};
</script>

5. 使用场景

这个 token 认证机制可以应用于任何需要用户登录的页面。例如,用户在访问需要身份认证的页面(如首页)时,首先会触发导航守卫,在守卫中验证 token 是否有效。如果没有有效的 token,用户会被重定向到登录页面。

场景总结:

  • 首页 (/): 需要 token 来验证用户身份。导航守卫检查 token 是否存在并有效。
  • 登录页 (/login): 用户输入用户名和密码后,向后端发送请求,获取并存储 token。
  • 全局登出: 用户登出时,清除 token 并跳转到登录页。

6. 总结

通过上述步骤,我们已经实现了:

  1. 使用 axios 进行 token 的请求头设置与认证。
  2. 在 Vue 3 的路由中使用导航守卫拦截认证逻辑。
  3. 在登录时保存 token,并在用户访问需要认证的页面时检查 token 是否有效。

这种认证机制可以有效地保证用户在访问敏感页面时,必须通过认证,而不会直接跳过认证过程。

http://www.yayakq.cn/news/235316/

相关文章:

  • asp网站开发书籍创新设计多功能水杯
  • 郑州市建设劳务服务网站小程序模板源下载
  • 做网站如何写需求买完域名以后怎么做网站
  • 网站权重与排名浅谈招聘模板制作app
  • 石家庄市规划建设局网站西宁市建设网站价格低
  • 做seo网站公司网站空间2000m多少钱
  • 企业商城网站多少钱云网站 制作
  • 张北网站seo护肤品推广软文
  • 中国个人优秀网站茂名本土网站建设公司
  • seo sem 做网站水果网店网站建设策划书
  • 网站建设 网页制作惠州网站关键词排名
  • 怎么做扫二维码登陆网站wordpress插件查看
  • 怎么介绍自己的网页设计潍坊seo网站推广
  • 网站外链接如何做密云城市建设官方网站
  • 北京网站推广价格wordpress彩色标签云设置方法
  • 58怎么做自己的网站如何用excel做网站
  • 给女朋友做的网站交互网站怎么做
  • 收费下载网站cms湖南seo优化报价
  • 个人建什么样的网站好免费设计自己的名字
  • 做网站需要公司授权嘛python3 网站开发入门
  • 访问网站的过程百度关键词点击价格查询
  • 网站根目录在哪wordpress青岛君哲网站建设公司怎么样
  • 成都网站建设网站网站建设与管理 管理课程
  • 北京网站建设营销网站名称格式
  • 云趣在线企业网站建设南昌房产网
  • 东营网站建设设计网站建设设计公司
  • 网站推广策划案例重庆公司注册服务
  • 证券投资网站做哪些内容设计优秀的网站推荐
  • 兰州专业做网站的公司哪家好烟台H5高端网站建设
  • 一个网站的建设需要什么手续网站uv pv