Activation de CORS dans Laravel 5.1
Lors du développement d'API avec Laravel 5.1, l'activation du partage de ressources d'origine croisée (CORS) est cruciale pour autoriser les requêtes d'origines différentes. Bien qu'il existe diverses bibliothèques CORS, cet article se concentre sur une implémentation de middleware personnalisée spécifiquement adaptée à Laravel 5.1.
Middleware pour CORS
Pour activer CORS, créez une classe de middleware dans app/Http/Middleware/CORS.php :
use Closure; class CORS { public function handle($request, Closure $next) { header("Access-Control-Allow-Origin: *"); $headers = [ 'Access-Control-Allow-Methods' => 'POST, GET, OPTIONS, PUT, DELETE', 'Access-Control-Allow-Headers' => 'Content-Type, X-Auth-Token, Origin' ]; if ($request->getMethod() == "OPTIONS") { return Response::make('OK', 200, $headers); } $response = $next($request); foreach ($headers as $key => $value) { $response->header($key, $value); } return $response; } }
Enregistrement du Middleware
Enregistrez votre middleware dans l'application/Http/Kernel.php :
protected $routeMiddleware = [ 'cors' => 'App\Http\Middleware\CORS', ];
Utilisation du Middleware
Pour utiliser CORS middleware dans une route, ajoutez 'middleware' => 'cors' à la définition de la route :
Route::get('example', ['middleware' => 'cors', function () { return 'example'; }]);
Mise à jour Laravel ^8.0
Dans les versions 8.0 et supérieures de Laravel, vous devez importer l'espace de noms du contrôleur et utiliser le nom de classe comme ceci :
use App\Http\Controllers\ExampleController; Route::get('example', [ExampleController::class, 'dummy'])->middleware('cors');
En suivant ces étapes, vous pouvez facilement activer CORS dans votre Laravel API 5.1, permettant les requêtes de différents domaines et fournissant un environnement API sécurisé et flexible.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!