【问题标题】:Cross-Origin HTTP Request originating from server-side NodeJS/Axios/JSDOM源自服务器端 NodeJS/Axios/JSDOM 的跨域 HTTP 请求
【发布时间】:2018-12-05 20:21:06
【问题描述】:

我正在使用 Axios 向不同域中的 API 服务器创建 HTTP 请求。

  • API 服务器允许来自http://localhost:3000 的跨域请求。
  • 我无法控制 API 服务器。
  • 我的应用程序通常在http://localhost:3000 中运行并从浏览器发出请求。

到目前为止没有问题。跨域请求工作正常。但是,最近我想为这些 API 调用添加一个单元测试。这个测试环境是jsdom,因为我使用的是Jest。当我从服务器端创建 HTTP 请求时,这会引发一个问题,源设置为 http://localhost,这是服务器不允许的。

请求是使用 Axios 发出的:

axios.post(`${API_DOMAIN}/member/account/login`, {
  username,
  password,
}, {
  headers: {
    Origin: 'http://localhost:3000'
  }
})

但是,响应仍然说

error: Cross origin http://localhost forbidden

如何将我在jsdom下用axios创建的http请求的“来源”改为http://localhost以外的?我需要它是 http://localhost:3000 以便 API 服务器允许我。

【问题讨论】:

    标签: node.js http cors axios


    【解决方案1】:

    原来jsdom 是创建源localhost 并阻止跨源请求的人。从https://github.com/axios/axios/issues/1180 我能够解决我的问题。在测试套件中,将此代码放在 axios 的任何 HTTP 请求之前:

    axios.defaults.adapter = require('axios/lib/adapters/http')
    

    这将使 Axios 使用 NodeJS 的 HTTP 适配器而不是 JSDOM 的 XMLHttpRequests。这样就不存在跨域问题了。

    【讨论】:

    • 你拯救了我的一天。谢谢
    • 为我工作,谢谢!
    • 这很好用。我尝试将 testEnvironment: 'node' 添加到我的 jest.config.js 中,这也有效
    猜你喜欢
    • 2018-03-02
    • 2012-04-18
    • 1970-01-01
    • 2012-10-24
    • 1970-01-01
    • 2014-07-23
    • 2018-04-01
    • 2015-07-25
    • 1970-01-01
    相关资源
    最近更新 更多