Fatigué des middleware personnalisés pour forcer les réponses JSON pour les exceptions API à Laravel? Laravel 11 rationalise ce processus. Cette approche élimine le besoin de middleware comme celui-ci:
class ForceJsonResponse { public function handle(Request $request, Closure $next) { $request->headers->set('Accept', 'application/json'); return $next($request); } }
Maintenant, vous pouvez obtenir le même résultat directement dans la configuration de votre application:
// bootstrap/app.php return Application::configure(basePath: dirname(__DIR__)) //... ->withExceptions(function (Exceptions $exceptions) { $exceptions->shouldRenderJsonWhen(function (Request $request, Throwable $e) { return $request->is('api/*'); }); })->create();
Ce code concise, en tirant parti de la méthode shouldRenderJsonWhen()
, garantit que toutes les exceptions dans les routes API (api/*
) sont rendues en JSON, quel que soit l'en-tête Accept
. N'oubliez pas que vous devrez toujours gérer les réponses non error pour garantir qu'ils renvoient également JSON.
Cette solution élégante provient directement de la documentation de Laravel, une précieuse ressource offrant des conseils supplémentaires sur la limitation des exceptions, la personnalisation de la réponse aux erreurs, et plus encore.
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!