无法获取Response Header内容的问题

无法获取Response Header内容的问题

因为公司的接口返回的格式都是固定的,所以我们前端在请求的时候都会对response进行统一处理,例如接口请求成功返回response.data.data。但是最近遇到了一个很神奇的问题,无法获取到Response Header的值。

问题的发现及排查

我们公司的接口服务器使用Nginx做了统一的代理处理,我们其实可以直接通过设置axios的baseURL来进行请求也就是直接使用接口服务器域名+接口地址拼接进行请求,但是这个新的项目默认使用的是前端代理,所以我就使用的前端代理。

然后我就发现在联调某个接口的时候使用代理和不使用代理,这个接口的返回值居然是不一样的。于是我去拦截器中查看了一下逻辑,发现为了使用文件下载,后端会使用Content-Disposition来指定接口返回内容,如果指定了该字段则说明该接口返回的是二进制文件,此时对于接口的返回值不会进行处理而是直接返回整个response。然后我打印了一下这个值,发现前端其实一直都没有接收到这个值。

原因

原因很简单,浏览器因为安全做出了限制,只有七种 simple response headers默认暴露可以被浏览器获取:

  1. Cache-Control
  2. Content-Language
  3. Content-Length
  4. Content-Type
  5. Expires
  6. Last-Modified
  7. Pragma

解决

需要服务器设置响应首部 Access-Control-Expose-Headers暴露出允许获取的Response Header

如果没有使用Nginx做转发的可以直接设置请求头:

public boolean preHandle(HttpServletRequest httpServletRequest,
                             HttpServletResponse httpServletResponse,
                             Object object) throws Exception{
        httpServletResponse.setHeader("Access-Control-Expose-Headers","Content-Disposition");
        return true;
}

如果是使用Nginx的话则需要在Nginx添加如下配置:

add_header 'Access-Control-Expose-Headers' 'Content-Disposition';

最近更新

  1. TCP协议是安全的吗?

    2024-06-17 02:54:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-17 02:54:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-17 02:54:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-17 02:54:03       20 阅读

热门阅读

  1. python单元测试

    2024-06-17 02:54:03       7 阅读
  2. exit和_exit函数和atexit函数

    2024-06-17 02:54:03       6 阅读
  3. GitHub项目里的api

    2024-06-17 02:54:03       7 阅读
  4. 算法训练营day60

    2024-06-17 02:54:03       8 阅读
  5. 15. 三数之和

    2024-06-17 02:54:03       5 阅读
  6. 【C++】类相关知识

    2024-06-17 02:54:03       7 阅读
  7. ubuntu commands

    2024-06-17 02:54:03       6 阅读
  8. 【Linux】如何查看网卡驱动

    2024-06-17 02:54:03       10 阅读
  9. MySql 数据库、表常用语句

    2024-06-17 02:54:03       5 阅读
  10. Linux 常用命令

    2024-06-17 02:54:03       5 阅读
  11. 简单的线程池示例

    2024-06-17 02:54:03       8 阅读