0

0

如何在 Vue3 中正确传递 Bearer Token 以避免 401 错误

霞舞

霞舞

发布时间:2026-01-25 11:59:21

|

372人浏览过

|

来源于php中文网

原创

如何在 Vue3 中正确传递 Bearer Token 以避免 401 错误

vue3 应用中调用登录接口后虽已将 token 存入 localstorage,但后续 api 请求仍返回 401,根本原因在于 axios 并未自动读取并携带该 token —— 必须显式在请求头中设置 `authorization: bearer `。

上述代码看似逻辑连贯:登录成功 → 保存 token → 获取用户数据 → 跳转首页。但问题出在 axios.get('user/userdata') 这一行——它默认不读取 localStorage 中的 token,也不会自动添加 Authorization 请求头,因此后端因缺少有效认证凭据而返回 401 Unauthorized。

✅ 正确做法是:在每次需要鉴权的请求中,手动注入 token 头。修改后的关键代码如下:

const response = await axios.post('user/login', {
  email: this.email,
  password: this.password
}).then(async (response) => {
  console.log('Login success:', response.data);

  // ✅ 正确保存 token
  localStorage.setItem('token', response.data.token);

  // ✅ 关键修复:显式传入 Authorization 头
  const userdata = await axios.get('user/userdata', {
    headers: {
      Authorization: `Bearer ${localStorage.getItem('token')}`
    }
  });

  this.$store.dispatch('user', userdata.data.userDataDTO);
  this.$router.push('/home');
}).catch(err => {
  console.error('Login request failed:', err.response?.data || err.message);
  this.failedToLogin = true;
});

⚠️ 注意事项:

  • 不要依赖“先存后用”的时序假定:localStorage.setItem() 是同步操作,但 axios 请求本身不感知存储状态,必须主动传参;
  • 避免重复获取 token:localStorage.getItem('token') 在此处是安全且必要的,无需额外判断(若为空,后端自然返回 401,便于统一错误处理);
  • 更优实践:建议将 token 注入逻辑全局化,例如通过 axios 拦截器统一设置请求头,避免每个请求都手动写:
// main.js 或 api/utils.js 中配置
axios.interceptors.request.use(config => {
  const token = localStorage.getItem('token');
  if (token) {
    config.headers.Authorization = `Bearer ${token}`;
  }
  return config;
});

这样,所有后续 axios.get()、axios.post() 等请求都会自动携带 token,大幅提升可维护性与健壮性。

Bardeen AI
Bardeen AI

使用AI自动执行人工任务

下载

立即学习前端免费学习笔记(深入)”;

? 补充说明:你提到“刷新页面后能自动登录”,正是因为初始化时(如路由守卫或 store 模块)显式读取了 localStorage 并设置了请求头(或已触发拦截器),印证了问题本质不是 token 无效,而是缺失主动授权声明。始终牢记:前端存储 ≠ 自动认证——安全机制要求每次请求都明确声明身份。

相关专题

更多
登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6112

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

816

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1064

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1302

2024.03.01

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1072

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

128

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

974

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 7.1万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号