vue 超时设置,不操作系统,超时退出;一直操作系统,以最后一次操作系统为准算超时时间

最近在项目过程中加超时的设置,登录后,每次后台都会在response的头部返回给一个token,并且利用这个token作为新的请求头部的token传给后台,以此来保证在操作系统的过程中,不会因为超时而被强制退出系统的不合理要求

一直在操作系统,超时时间的开始时间以最后一次操作系统的时间开始计时

我们可以在自主封装的接口里面写这个方法,但是我们需要在后台返回的response的headers里面拿到最新的token,但是一般情况下我们只能在response的headers里面看到type,看不到token,这就让我们前台不会拿到这个token

后来经过一番查找终于找到

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

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

若想让浏览器能访问到其它响应头(例如后台新加的token)则需在服务器上设置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啦

参考

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值