无法在CodeIgniter和React app之间使用CORS

时间:2017-02-24 17:45:42

标签: php codeigniter http reactjs cors

我无法让我的React应用与我在计算机上托管的API进行通信。我对CodeIgniter不太熟悉,因此可以安全地承担错误/误解。我尝试将header('Access-Control-Allow-Origin:*');添加到application/config/rest.php的顶部以及其他一些文件。当我执行api请求时,显然首先发送了一个飞行前OPTIONS请求,如下所示:

Request Headers:
Host: localhost:8000
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:51.0) Gecko/20100101 Firefox/51.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Access-Control-Request-Method: GET
Access-Control-Request-Headers: apikey
Origin: http://localhost:3000
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache

Response Headers:
Access-Control-Allow-Origin: *
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Connection: close
Content-Type: text/html; charset=UTF-8
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Host: localhost:8000
Pragma: no-cache
Set-Cookie: ci_session=3ba4cibif5sdgtfjjopmokt8k2fc1c1j; expires=Fri, 24-Feb-2017 19:18:05 GMT; Max-Age=7200; path=/; HttpOnly
X-Powered-By: PHP/5.5.38

OPTIONS响应是200.在服务器上,API播种我想要获取的资源并以200响应(但是我的应用程序没有看到这个)。反应前端看到并记录了一个非常无用的

Error: Network Error
Stack trace:
createError@http://localhost:3000/bundle.js line 4801 > eval:15:15
handleError@http://localhost:3000/bundle.js line 4789 > eval:87:14

错误,我的应用程序甚至从未做过GET请求(根据Firefox的开发工具)。 OPTION的响应数据完全为空。这是怎么回事?

1 个答案:

答案 0 :(得分:1)

结果我需要检查它是否是服务器上的预检请求,并做出适当的响应:

header('Access-Control-Allow-Origin: *');
header("Access-Control-Allow-Headers: X-API-KEY, Origin, X-Requested-With, Content-Type, Accept, Access-Control-Request-Method");
header("Access-Control-Allow-Methods: GET, POST, OPTIONS, PUT, DELETE");
$method = $_SERVER['REQUEST_METHOD'];
if($method == "OPTIONS") {
    die();
}

然后我可以使用标题中的api键发出正常请求。

来自https://stackoverflow.com/a/19310265/419194