Heim >PHP-Framework >Laravel >So legen Sie die Gültigkeitsdauer des Bildzugriffs in Laravel fest

So legen Sie die Gültigkeitsdauer des Bildzugriffs in Laravel fest

PHPz
PHPzOriginal
2023-04-12 09:13:37910Durchsuche

Laravel ist ein sehr beliebtes Webentwicklungs-Framework. Bei der Webentwicklung treten häufig Probleme im Zusammenhang mit dem Hochladen, der Speicherung und dem Zugriff von Bildern auf. Das Festlegen der Gültigkeitsdauer des Bildzugriffs ist eine sehr wichtige Aufgabe, die die Sicherheit von Bildern wirksam schützen und unnötige Sicherheitsrisiken vermeiden kann.

Für die Einstellung des Gültigkeitszeitraums für den Bildzugriff des Laravel-Frameworks können verschiedene Lösungen übernommen werden. In diesem Artikel werden einige häufig verwendete Lösungen vorgestellt, in der Hoffnung, für Laravel-Entwickler hilfreich zu sein.

1. Implementierung durch Middleware

Middleware im Laravel-Framework ist ein praktischer Mechanismus zur Verarbeitung von Anfragen und Antworten. Der Gültigkeitszeitraum des Bildzugriffs kann in der Middleware festgelegt werden.

Zuerst können wir eine neue Middleware erstellen, z. B. ExpiresMiddleware. Der Code lautet wie folgt:

<?php

namespace App\Http\Middleware;

use Closure;

class ExpiresMiddleware
{
    public function handle($request, Closure $next)
    {
        $response = $next($request);

        $response->header('Cache-Control', 'public, max-age=86400');
        $response->header('Expires', gmdate('D, d M Y H:i:s \G\M\T', time() + 86400));

        return $response;
    }
}

In dieser Middleware legen wir die Felder Cache-Control und Expires des Antwortheaders fest. Unter anderem gibt Cache-Control die Cache-Richtlinie als öffentlich an und der Gültigkeitszeitraum beträgt 86400 Sekunden. Expires gibt die Ablaufzeit der Antwort als aktuelle Zeit + 86400 Sekunden an.

Dann können wir diese Middleware auf eine Route oder einen Controller in der Laravel-Anwendung anwenden, zum Beispiel:

Route::get('/image/{id}', 'ImageController@show')->middleware('expires');

In diesem Beispiel legen wir die ExpiresMiddleware-Middleware für die Route /image/{id} fest.

Mit den oben genannten Einstellungen enthält der durch den Zugriff auf diese Route zurückgegebene Bildantwortheader die Felder „Cache-Control“ und „Expires“. Der Browser speichert das Bild im Cache und fordert das Bild nach 86400 Sekunden erneut an.

2. Implementierung durch Nginx-Konfiguration

Zusätzlich zur Einstellung über die Laravel-Middleware können Sie die Gültigkeitsdauer des Bildzugriffs auch über die Nginx-Konfiguration festlegen.

Zuerst müssen wir die Konfiguration der Bildressourcen in der Nginx-Konfigurationsdatei hinzufügen, zum Beispiel:

location ~* \.(gif|jpg|png)$ {
    expires 1d;
}

In diesem Beispiel legen wir das Ablauffeld für alle GIF-, JPG- und PNG-Bildressourcen so fest, dass sie nach einem Tag ablaufen. Auf diese Weise gibt Nginx beim Zugriff auf die Bildressource einen Antwortheader zurück, der das Ablauffeld enthält, und der Browser speichert das Bild zwischen und fordert das Bild nach einem Tag erneut an.

Mit der oben genannten Methode können wir in der Nginx-Konfigurationsdatei eine flexible Gültigkeitsdauer für den Bildzugriff festlegen, um die Sicherheit und Zugriffsgeschwindigkeit von Bildern zu verbessern.

Zusammenfassung:

Im Entwicklungsprozess von Laravel ist das Festlegen der Zugriffsgültigkeitsdauer von Bildern eine sehr wichtige Aufgabe. In Bezug auf die Implementierung können wir verschiedene Einstellungen über die Laravel-Middleware oder die Nginx-Konfiguration konfigurieren.

Durch die obige Einführung glaube ich, dass Sie verstanden haben, wie Sie die Gültigkeitsdauer des Bildzugriffs in Laravel festlegen. Ich hoffe, dass dies für Ihre Laravel-Entwicklungspraxis hilfreich sein wird.

Das obige ist der detaillierte Inhalt vonSo legen Sie die Gültigkeitsdauer des Bildzugriffs in Laravel fest. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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