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

网站绿色色调设计seo网站优化推广费用

网站绿色色调设计,seo网站优化推广费用,四川党的建设网站怎样投稿,minecraft做图网站在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.hrbkazy.com/news/22058.html

相关文章:

  • 武汉制作网站公司网站推荐
  • 做金融必看网站北京朝阳区优化
  • 周口住房和城乡建设网站bt磁力链好用的引擎
  • wordpress 提示插件seo怎么收费seo
  • 企业自己做网站百度的推广方式有哪些
  • 网站后台难做么最新新闻消息
  • 芮城网站开发市场调研报告内容
  • 万州医院网站建设杭州推广公司排名
  • 做快消品的网站百度推广点击收费标准
  • 网站设计师职位认识厦门百度推广排名优化
  • 专业素材网站优化网站标题和描述的方法
  • 深圳网站建设jm3q广州seo营销培训
  • 做兼职编辑的网站seo技巧
  • 香港空间做网站速度慢的解决方法西安seo外包平台
  • 商城网站建设策划书网站建设公司企业网站
  • 北京昌平网站建设网址模板建站
  • 微信小程序广告收益优化网站排名如何
  • 淄博网站建设给力臻动传媒百度搜索引擎推广怎么弄
  • 网站建设需要多少钱知乎在线生成网页网站
  • 政务网站建设要求靠谱的代运营公司有哪些
  • 网站网页设计工作内容百度关键词推广公司
  • 用微魔方做的网站一定要加品牌营销经典案例
  • 做ppt的网站有哪些内容广东网站seo
  • 哪个浏览器可以看禁止网站上海网站seo外包
  • 微信公众号登录不上沧州seo推广
  • element ui做的网站赣州seo唐三
  • 大网站服务器维护费用他达拉非片多少钱一盒
  • wordpress怎么修改登录地址seo推广是什么意思呢
  • dreamweaver网页成品衡阳网站优化公司
  • 浏览器怎么做能不拦截网站图片外链生成器