我所有的 DELETE 和 PUT 请求都被阻止 (405)。我尝试将标题放在过滤器之前和之后:
App::before(function($request)
{
header('Access-Control-Allow-Origin', '*');
header('Allow', 'GET, POST, OPTIONS, PUT, DELETE');
header('Access-Control-Allow-Headers', 'Origin, Content-Type, Accept, Authorization, X-Request-With');
header('Access-Control-Allow-Credentials', 'true');
});
App::after(function($request, $response)
{
$response->headers->set('Access-Control-Allow-Origin', '*');
$response->headers->set('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
$response->headers->set('Access-Control-Allow-Headers', 'Origin, Content-Type, Accept, Authorization, X-Requested-With');
$response->headers->set('Access-Control-Allow-Credentials', 'true');
$response->headers->set('Access-Control-Max-Age','86400');
return $response;
});
我尝试添加 .htaccess 规则以允许它们在 laravel 公用文件夹中:
<Limit GET POST PUT DELETE HEAD OPTIONS>
Order allow,deny
# You might want something a little more secure here, this is a dev setup
Allow from all
</Limit>
<LimitExcept POST PUT DELETE HEAD OPTIONS>
Order deny,allow
Deny from all
</LimitExcept>
我尝试在资源控制器中使用构造函数,但实际上似乎没有任何一种请求类型允许。我在这里很快就没有想法了,我正在使用 apache 和 kendo UI 发出 AJAX 请求。我的路线看起来像:
// PUBLIC
Route::group(array('prefix' => 'api/v1'), function()
{
Route::post('login', array('uses'=>'UsersController@login'));
Route::get('status', array('uses'=>'UsersController@status'));
});
// PROTECTED BY SENTRY
Route::group(array('prefix' => 'api/v1', 'before' => 'auth'), function()
{
Route::get('logout', array('uses'=>'UsersController@logout'));
Route::get('users/whoami', array('uses'=>'UsersController@whoami'));
Route::resource('users', 'UsersController');
Route::resource('programs', 'ProgramsController'); // THIS ROUTE KEEPS 405'ING ME
});
过滤器文件没有什么花哨的,只是使用 Sentry2 进行用户管理。任何帮助将不胜感激!