Enable CORS via Middleware in Laravel

If you don’t have any idea what CORS is, then please skip this.

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Response;
class CORS
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
$origin = request()->headers->get('origin', '*');
$headers = [
'Access-Control-Allow-Methods' => 'GET, PUT, POST, DELETE, OPTIONS',
'Access-Control-Allow-Headers' => 'Content-Type, X-Auth-Token, Origin, Authorization, apitoken, ApiToken',
'Access-Control-Allow-Origin' => $origin,
'Access-Control-Allow-Credentials' => 'true',
];
if ($request->getMethod() == "OPTIONS") {
return response('', 200)->withHeaders($headers);
}
$response = $next($request);
foreach ($headers as $key => $value) {
$response->header($key, $value);
}
return $response;
}
}
view raw CORS.php hosted with ❤ by GitHub

Save as CORS.php in the Middleware folder.

Edit app\Http\Kernel.php and add your middleware in api / routeMiddleware.

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.


Notice: ob_end_flush(): failed to send buffer of zlib output compression (0) in /home/saiful/public_html/wp-includes/functions.php on line 5464