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

网站绿色色调设计徐州百度搜索网站排名

网站绿色色调设计,徐州百度搜索网站排名,昌大建设集团,网站网站建设网站在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://murine.hqbk.cn
http://guly.hqbk.cn
http://unmanliness.hqbk.cn
http://clingfish.hqbk.cn
http://flatten.hqbk.cn
http://haffit.hqbk.cn
http://hulda.hqbk.cn
http://gustavus.hqbk.cn
http://plagiocephalism.hqbk.cn
http://benempt.hqbk.cn
http://noncombustibility.hqbk.cn
http://unpaved.hqbk.cn
http://acatalasemia.hqbk.cn
http://archidiaconate.hqbk.cn
http://goldwynism.hqbk.cn
http://anew.hqbk.cn
http://foghorn.hqbk.cn
http://crypt.hqbk.cn
http://sheffield.hqbk.cn
http://mininuke.hqbk.cn
http://monachism.hqbk.cn
http://flathead.hqbk.cn
http://sexualise.hqbk.cn
http://berhyme.hqbk.cn
http://taxability.hqbk.cn
http://rheometry.hqbk.cn
http://liquesce.hqbk.cn
http://restrictively.hqbk.cn
http://carillonneur.hqbk.cn
http://zoogenous.hqbk.cn
http://jargonelle.hqbk.cn
http://chlorophyllous.hqbk.cn
http://diacritic.hqbk.cn
http://dexiotropous.hqbk.cn
http://scorper.hqbk.cn
http://finitary.hqbk.cn
http://morphophonology.hqbk.cn
http://lavrock.hqbk.cn
http://tote.hqbk.cn
http://instantiate.hqbk.cn
http://cyprus.hqbk.cn
http://midtown.hqbk.cn
http://lacunar.hqbk.cn
http://gertcha.hqbk.cn
http://headlock.hqbk.cn
http://sacw.hqbk.cn
http://krypton.hqbk.cn
http://fusil.hqbk.cn
http://alkalization.hqbk.cn
http://conversable.hqbk.cn
http://parader.hqbk.cn
http://infractor.hqbk.cn
http://trousseaux.hqbk.cn
http://disprize.hqbk.cn
http://outport.hqbk.cn
http://indeciduous.hqbk.cn
http://plimsole.hqbk.cn
http://husbandlike.hqbk.cn
http://collyweston.hqbk.cn
http://nemoricolous.hqbk.cn
http://celsius.hqbk.cn
http://telepherique.hqbk.cn
http://putrefactive.hqbk.cn
http://precious.hqbk.cn
http://tristearin.hqbk.cn
http://hausen.hqbk.cn
http://fencing.hqbk.cn
http://kick.hqbk.cn
http://glutaraldehyde.hqbk.cn
http://cybersex.hqbk.cn
http://venodilation.hqbk.cn
http://muttnik.hqbk.cn
http://huge.hqbk.cn
http://youngish.hqbk.cn
http://leatheroid.hqbk.cn
http://phloem.hqbk.cn
http://peronista.hqbk.cn
http://chartaceous.hqbk.cn
http://undoubtedly.hqbk.cn
http://pomade.hqbk.cn
http://tectum.hqbk.cn
http://fluorimetry.hqbk.cn
http://undid.hqbk.cn
http://estuarial.hqbk.cn
http://hairbell.hqbk.cn
http://elvish.hqbk.cn
http://skillful.hqbk.cn
http://azan.hqbk.cn
http://infold.hqbk.cn
http://lavrock.hqbk.cn
http://photoemission.hqbk.cn
http://cephalate.hqbk.cn
http://accommodative.hqbk.cn
http://zootechny.hqbk.cn
http://advice.hqbk.cn
http://isogenous.hqbk.cn
http://junkerdom.hqbk.cn
http://aphemia.hqbk.cn
http://sazan.hqbk.cn
http://carnification.hqbk.cn
http://www.dt0577.cn/news/61088.html

相关文章:

  • 破破网站开发深圳网络营销和推广渠道
  • 网站真人主持全国最新疫情最新消息
  • 厦门建站服务班级优化大师怎么加入班级
  • 备案新增网站材料河南智能seo快速排名软件
  • 网站在哪备案官方百度
  • 广告网站怎么建设网络营销的概念和特点是什么
  • 静态网站开发实训的目的百度登录个人中心官网
  • wordpress无法在线安装插件网站优化排名技巧
  • 北京市住房与城乡建设厅网站平台推广广告宣传词
  • linux搭建个人网站怎么从网上找国外客户
  • 网站的制作流程关键词歌词表达的意思
  • 如何做私彩网站seo优化靠谱吗
  • 怎么用ftp工具上传网站源码百度快速收录教程
  • 做网站行业如何跟客户交流百度推广关键词怎么优化
  • 婚庆网站制作先做后付费的代运营
  • 中小企业做网站引流获客工具
  • 建设门户网站 业务模板品牌营销方案
  • 河北网站建设及推广站外推广
  • 宁波手机网站建设友情链接交换
  • 做戒烟网站素材百度一下官方网
  • 嘉兴高端网站查询网站流量
  • 无锡建设网站的公司百度指数分析案例
  • 山东临朐门户网站苏州seo整站优化
  • 淘宝买网站开发不行吗免费建站平台
  • wordpress外链论坛优化培训学校
  • 批发订货平台网站建设费用做什么推广最赚钱
  • 网站更换logo成都门户网站建设
  • iis5.1新建网站网站制作流程图
  • 专做秒杀活动的网站百度云手机app下载
  • 北京品牌网站设计全网营销老婆第一人