解决Axios发送Ajax请求获取不到Header响应头里的Token

问题描述

在做登录功能的时候 调用登录接口 想获取Header里的Token 然而发现里面并没有Token:
在这里插入图片描述
在用Postman测试的时候发现是正常的:
在这里插入图片描述

原因

浏览器默认只能访问以下几种响应头:

  • Cache-Control
  • Content-Length
  • Content-Type
  • Expires
  • Pragma

若想让浏览器能访问到其它响应头 则需在服务器上设置Access-Control-Expose-Headers
其值为要被访问的响应头的属性名

解决方法

在拦截器里进行配置 添加响应头

public class JWTAuthenticationFilter extends UsernamePasswordAuthenticationFilter {

    ...
    
    @Override
    protected void successfulAuthentication(HttpServletRequest request,HttpServletResponse response,FilterChain chain,Authentication authResult) throws IOException {
       
        ...

        // 让浏览器能访问到其它响应头
        response.addHeader("Access-Control-Expose-Headers","token");

        ...
    }
    
    ...
    
}

成功拿到token:
在这里插入图片描述


  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值