在CakePHP应用程序中启用CORS

前端之家收集整理的这篇文章主要介绍了在CakePHP应用程序中启用CORS前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试为Cake PHP中内置的API启用CORS,以便可以使用AppController中的以下内容访问所有请求:
public function beforeFilter()
{
    header("Access-Control-Allow-Origin: *");
}

这是在错误的地方吗?由于请求仍然被阻止.

更新:似乎这确实工作但是因为我做的事情如下:

header('Content-Type: application/json');
echo json_encode(array('message'=>'Hello world!'));

在我的一些方法中,它表现为好像它覆盖了标头设置AppController,所以它没有出现在JSON调用的响应中.
有任何想法吗?

更新2:如下所示返回JSON,修复了问题:

$this->response->type('json');
$this->response->body(json_encode(array('message'=>'Hello world!')));

显然在Cake中使用header()打破了以前的标题

你可以使用cake response对象来做到这一点;
$this->response->header('Access-Control-Allow-Origin','*');

有关响应对象的更多信息;
http://book.cakephp.org/2.0/en/controllers/request-response.html#setting-headers

但是,beforeRender()回调似乎更合乎逻辑.

另一种选择是在你的apache vhost或htaccess中添加这个头文件,可以在Html5Boilerplate的htaccess文件中找到,这是一个非常有趣的事情(有详细记录),因为它包含很多优化,可以很好地与cakePHP一起工作好;

https://github.com/h5bp/server-configs-apache/blob/master/dist/.htaccess

http://html5boilerplate.com/

猜你在找的PHP相关文章