@legolas4444

Как работает CORS в Laravel 5?

Всем привет! Разрабатываю публичное API и клиент к нему на AngularJS. Столкнулся с проблемой связаной с CORS.
Сделал такой миделвар:
<?php

namespace App\Http\Middleware;

use Closure;

class CorsMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        return $next($request)->header('Access-Control-Allow-Origin' , '*')
            ->header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS, PATCH, HEAD')
            ->header('Access-Control-Allow-Headers', 'Authorization');
    }
}

Но я получаю ошибку:
XMLHttpRequest cannot load http://api.v1.example.local/signup. Response to preflight request doesn't pass access control check: The 'Access-Control-Allow-Origin' header contains multiple values '*, *', but only one is allowed. Origin 'http://german-front.local' is therefore not allowed access.

А если дописать в .htaccess
<IfModule mod_headers.c>
   Header set Access-Control-Allow-Origin "*"
   Header set Access-Control-Allow-Methods "GET, POST, PUT, DELETE, OPTIONS, PATCH, HEAD"
</IfModule>

то все работает. Казалось бы, работает - пусть работает. Но интересно выяснить почему так только всё происходит? Кто что думает?

P.s Заметил странную особенность. Когда посылается OPTIONS - то заголовки возвращаются, а вот последующий POST запрос нужных заголовков не получает..
  • Вопрос задан
  • 6331 просмотр
Пригласить эксперта
Ответы на вопрос 1
Denormalization
@Denormalization
Посмотрите как реализованно тут https://github.com/barryvdh/laravel-cors (а конкретно тут https://github.com/asm89/stack-cors/blob/master/sr... методы isPreflightRequest, handlePreflightRequest)
Советую этот пакет, с ним не было проблем.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы