Heim > PHP-Framework > Laravel > Hauptteil

Ausnahmebehandlung für Laravel-Anfragen

王林
Freigeben: 2023-05-26 16:35:07
Original
1282 Leute haben es durchsucht

Laravel ist ein beliebtes PHP-Framework, das ein leistungsstarkes und flexibles System zum Erstellen von Webanwendungen bietet. Während des Entwicklungsprozesses ist es jedoch unvermeidlich, dass Anforderungsausnahmen auftreten. In diesem Artikel besprechen wir, wie mit Laravel-Anfrageausnahmen umgegangen wird.

  1. Klassifizierung von Ausnahmen

Anforderungsausnahmen in Laravel können in zwei Typen unterteilt werden: Programmausnahmen und HTTP-Ausnahmen.

Programmausnahmen sind Ausnahmen, die auftreten, wenn der Code ausgeführt wird, z. B. von PHP ausgelöste schwerwiegende Fehler, nicht abgefangene Ausnahmen usw.

HTTP-Ausnahmen beziehen sich auf Ausnahmen, die in HTTP-Anfragen auftreten, wie z. B. 404 Not Found, 500 Internal Server Error usw.

Verschiedene Arten von Ausnahmen erfordern unterschiedliche Behandlungsmethoden.

  1. Behandlung von Programmausnahmen

Programmausnahmen können im Laravel-Controller auftreten. Wenn sie nicht behandelt werden, wird eine Seite mit einer Fehlermeldung angezeigt. Dies ist nicht das, was Benutzer erwarten, daher müssen Programmausnahmen behandelt werden.

Laravel bietet uns zwei Methoden zur Behandlung von Programmausnahmen. Die erste besteht darin, Ausnahmehandler zu verwenden, und die zweite darin, eine globale Ausnahmebehandlung zu verwenden.

2.1 Ausnahmehandler

Laravel-Ausnahmehandler ist eine Klasse, die von der Anwendung ausgelöste Ausnahmen verarbeitet. Wenn wir möchten, dass der Controller beim Auslösen einer Ausnahme eine Antwort im JSON-Format zurückgibt, können wir einen benutzerdefinierten Ausnahmehandler erstellen. Hier ist ein Beispiel:

<?php

namespace AppExceptions;

use Exception;
use IlluminateFoundationExceptionsHandler as ExceptionHandler;

class Handler extends ExceptionHandler
{
    /**
     * A list of the exception types that are not reported.
     *
     * @var array
     */
    protected $dontReport = [
        //
    ];

    /**
     * Report or log an exception.
     *
     * @param  Exception  $exception
     * @return void
     */
    public function report(Exception $exception)
    {
        parent::report($exception);
    }

    /**
     * Render an exception into an HTTP response.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  Exception  $exception
     * @return IlluminateHttpResponse
     */
    public function render($request, Exception $exception)
    {
        if ($exception instanceof IlluminateDatabaseEloquentModelNotFoundException) {
            return response()->json([
                'error' => 'Resource not found'
            ], 404);
        }

        return parent::render($request, $exception);
    }
}
Nach dem Login kopieren

In diesem Beispiel erben wir die Ausnahmehandlerklasse von Laravel und überschreiben die Methode render. In der Methode render prüfen wir, ob der Ausnahmetyp IlluminateDatabaseEloquentModelNotFoundException ist. Wenn ja, geben wir eine JSON-formatierte Antwort zurück. render 方法。在 render 方法中,我们检查了异常类型是否是 IlluminateDatabaseEloquentModelNotFoundException。如果是,我们返回一个 JSON 格式的响应。

我们还可以在这个方法中处理其他的程序异常。这种处理方式的好处是,我们可以为每种类型的异常编写自定义的处理器。这样我们就能够预测到我们会得到什么样的响应。

2.2 全局异常处理

使用全局异常处理,我们可以捕获应用程序中的所有异常,而不是为每种异常编写单独的处理器。下面是一个例子:

<?php

namespace AppExceptions;

use Exception;
use IlluminateFoundationExceptionsHandler as ExceptionHandler;

class Handler extends ExceptionHandler
{
    /**
     * A list of the exception types that are not reported.
     *
     * @var array
     */
    protected $dontReport = [
        //
    ];

    /**
     * Report or log an exception.
     *
     * @param  Exception  $exception
     * @return void
     */
    public function report(Exception $exception)
    {
        parent::report($exception);
    }

    /**
     * Render an exception into an HTTP response.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  Exception  $exception
     * @return IlluminateHttpResponse
     */
    public function render($request, Exception $exception)
    {
        if ($exception instanceof SymfonyComponentHttpKernelExceptionHttpException) {
            $code = $exception->getStatusCode();

            return response()->json([
                'error' => 'HTTP Exception',
                'status' => $code
            ], $code);
        }

        return parent::render($request, $exception);
    }

    /**
     * Render the given HttpException.
     *
     * @param  SymfonyComponentHttpKernelExceptionHttpException  $e
     * @return IlluminateHttpResponse
     */
    protected function renderHttpException(HttpException $e)
    {
        $status = $e->getStatusCode();

        if (view()->exists("errors.{$status}")) {
            return response()->view("errors.{$status}", ['exception' => $e], $status, $e->getHeaders());
        } else {
            return $this->convertExceptionToResponse($e);
        }
    }
}
Nach dem Login kopieren

在这个例子中,我们重写了 render 方法,检查异常类型是否是 SymfonyComponentHttpKernelExceptionHttpException。如果是,我们创建了一个 JSON 格式的响应,包括错误消息和 HTTP 状态码。

如果我们需要呈现 HTML 页面,我们还可以重写 renderHttpException 方法,以渲染自定义的异常页面。

  1. HTTP 异常的处理

Laravel 提供了一种简单的方法处理 HTTP 异常。通过自定义 app/Exceptions/Handler.php 中的 render 方法,我们可以返回指定的 HTTP 状态码。以下是一个例子:

public function render($request, Exception $exception)
{
    if ($this->isHttpException($exception)) {
        return $this->renderHttpException($exception);
    } else {
        return parent::render($request, $exception);
    }
}

protected function renderHttpException(HttpException $exception)
{
    return response()->view('errors.' . $exception->getStatusCode(), [], $exception->getStatusCode());
}
Nach dem Login kopieren

在上面的例子中,我们检查异常是否是 HTTP 异常。如果是,我们使用 getStatusCode 方法获取 HTTP 状态码,并将其用作视图名称。在这个例子中,我们只是返回了一个对应状态码的视图。

  1. 结论

在本文中,我们介绍了 Laravel 中程序和 HTTP 异常的处理方法。我们学习了如何使用异常处理器和全局异常处理来处理程序异常,以及如何自定义 render

Mit dieser Methode können wir auch andere Programmausnahmen behandeln. Der Vorteil dieses Ansatzes besteht darin, dass wir für jeden Ausnahmetyp benutzerdefinierte Handler schreiben können. Auf diese Weise können wir vorhersagen, welche Art von Reaktion wir erhalten werden. 🎜🎜2.2 Globale Ausnahmebehandlung🎜🎜Durch die globale Ausnahmebehandlung können wir alle Ausnahmen in der Anwendung abfangen, anstatt für jede Ausnahme separate Handler zu schreiben. Hier ist ein Beispiel: 🎜rrreee🎜In diesem Beispiel überschreiben wir die Methode render, um zu prüfen, ob der Ausnahmetyp SymfonyComponentHttpKernelExceptionHttpException ist. Wenn ja, erstellen wir eine JSON-formatierte Antwort einschließlich der Fehlermeldung und des HTTP-Statuscodes. 🎜🎜Wenn wir eine HTML-Seite rendern müssen, können wir auch die Methode renderHttpException überschreiben, um eine benutzerdefinierte Ausnahmeseite zu rendern. 🎜
    🎜HTTP-Ausnahmebehandlung🎜🎜🎜Laravel bietet eine einfache Möglichkeit, HTTP-Ausnahmen zu behandeln. Durch Anpassen der render-Methode in app/Exceptions/Handler.php können wir den angegebenen HTTP-Statuscode zurückgeben. Hier ist ein Beispiel: 🎜rrreee🎜Im obigen Beispiel prüfen wir, ob es sich bei der Ausnahme um eine HTTP-Ausnahme handelt. Wenn ja, verwenden wir die Methode getStatusCode, um den HTTP-Statuscode abzurufen und ihn als Ansichtsnamen zu verwenden. In diesem Beispiel geben wir lediglich eine Ansicht zurück, die dem Statuscode entspricht. 🎜
      🎜Fazit🎜🎜🎜In diesem Artikel haben wir vorgestellt, wie man Programm- und HTTP-Ausnahmen in Laravel behandelt. Wir haben gelernt, wie man Ausnahmehandler und globale Ausnahmebehandlung verwendet, um Programmausnahmen zu behandeln, und wie man die render-Methode für die Behandlung von HTTP-Ausnahmen anpasst. Für Laravel-Entwickler ist es sehr wichtig, Ausnahmen korrekt zu behandeln. Durch den Einsatz dieser Technologien können wir das Verhalten unserer Anwendungen genauer steuern und so deren Zuverlässigkeit und Stabilität verbessern. 🎜

Das obige ist der detaillierte Inhalt vonAusnahmebehandlung für Laravel-Anfragen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!