【发布时间】:2014-02-28 19:56:29
【问题描述】:
我一直在寻找解决这个问题的方法。
我有一个带有 Laravel 4 后端实现的 AngularJS Web 应用程序,如下所示:
http://app.mydomain.io/ = AngularJS web app
http://api.mydomain.io/ = Laravel Back-end
在 Laravel 的 routes.php 文件中,我有以下 PHP 代码来设置 Access-Control 标头:
header('Access-Control-Allow-Origin: http://app.mydomain.io');
header('Access-Control-Allow-Methods: POST, GET, OPTIONS, PUT, DELETE');
我还为登录请求设置了如下路由:
Route::post('/login', function()
{
$email = Input::get('email');
$password = Input::get('password');
if (Auth::attempt(array('email' => $email, 'password' => $password)))
{
return "Success!";
} else {
return "Fail!";
}
});
在 AngularJS 中,我有一个 AuthService,如下所示:
app.factory('AuthService', ['$resource', '$q', '$cookieStore', function($resource, $q, $cookieStore) {
var user = null;
var Service = $resource('//api.mydomain.io/login/', {}, {});
return {
login: function(email, password) {
var deferred = $q.defer();
Service.save({email: email, password: password}, function(response) {
$cookieStore.put('user', JSON.stringify(response));
deferred.resolve(true);
}, function(error) {
deferred.reject(error);
});
return deferred.promise;
}
};
}]);
发出此请求后,我得到以下信息:
XMLHttpRequest cannot load http://api.mydomain.io/login. Invalid HTTP status code 404
如果我将 Laravel 路由和 AngularJS 服务更改为使用 GET,一切都会按预期工作。问题源于 AngularJS .save() 发出 OPTIONS 请求而不是 POST(我不完全理解为什么)。
谁能帮我找到合适的最佳实践解决方案?
谢谢!
【问题讨论】:
标签: javascript php angularjs laravel cors