Heim > PHP-Framework > Laravel > Hauptteil

Wie Laravel ApiToken zur Authentifizierung von Anfragen verwendet

藏色散人
Freigeben: 2020-06-06 14:40:55
nach vorne
3593 Leute haben es durchsucht

In der folgenden Tutorial-Kolumne von Laravel Erste Schritte erfahren Sie, wie Sie die ApiToken-Authentifizierungsanfrage in Laravel verwenden. Ich hoffe, dass es für Freunde hilfreich ist, die es benötigen!

Wie Laravel ApiToken zur Authentifizierung von Anfragen verwendet

1. Öffnen Sie die Migrationsdatei „database/migrations/2014_10_12_000000_create_users_table.php“, wir müssen die Struktur der Benutzertabelle ändern

Wir müssen Fügen Sie das Feld api_token hinzu, das heißt, unser Token wird in der Datenbank gespeichert, fügen Sie eine Zeile hinzu

$table->string('api_token', 60)->unique();
Nach dem Login kopieren

3 Konfigurieren Sie die Datenbank und generieren Sie die Benutzertabelle

php artisan migrate Befehl 4. Fügen Sie in der Benutzertabelle nach Belieben einen Datensatz hinzu, solange das Feld api_token auf 123456 gesetzt ist. Auf diese Weise generieren wir einen Benutzer und können den Token-Wert 123456 verwenden, um uns später anzumelden.

5. Kehren Sie zur Routing-Datei „routes.php“ zurück, fügen Sie darin eine Testroute hinzu und schützen Sie sie mit Laravel-Middleware.

Route::group(['middleware' => ['auth.api']], function () { 
  Route::get('/t', function () {
      return 'ok';
  });
});
Nach dem Login kopieren

Hier wird die auth.api-Middleware und die Middleware verwendet Definition Geben Sie das Bild unten ein:

Wie Laravel ApiToken zur Authentifizierung von Anfragen verwendet

Erstellen Sie WebToken.php in der Middleware-Datei und registrieren Sie dann die Middleware in der Kernel.php-Datei

'auth.api' => \App\Http\Middleware\webToken::class,
Nach dem Login kopieren

6. Öffnen Sie den gerade erstellten WebToken-Middleware-Code wie folgt:

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Support\Facades\Auth;
class webToken
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if (Auth::guard(&#39;api&#39;)->guest()) {
            return response()->json([&#39;code&#39; => 401,&#39;msg&#39; => &#39;未设置token&#39;]);
        }
        return $next($request);
    }
}
Nach dem Login kopieren

Die API von Auth::guard('api') im Code ist die Datei auth.php im Konfigurationsordner

Wie Laravel ApiToken zur Authentifizierung von Anfragen verwendet

Wie Laravel ApiToken zur Authentifizierung von Anfragen verwendet

7 Wenn wir nach den oben genannten Änderungen eine direkte Anfrage an den Server mit dem URL-Pfad /t stellen, gibt der Server einen 401-Fehler zurück und a „Token nicht gesetzt“ Eine solche Nachricht haben wir zuvor in der Methode handle() festgelegt. Mit anderen Worten: /t wurde durch unsere Authentifizierungs-Middleware geschützt. Wenn wir möchten, dass unsere Anfrage diese Middleware normal durchläuft, müssen wir Folgendes bereitstellen token .

8. Da wir zuvor ein Datenelement mit api_token 123456 in der Benutzertabelle hinzugefügt haben, fordern wir jetzt erneut /t vom Server an, aber dieses Mal fügen wir api_token hinzu, also

…/t?api_token=123456
Nach dem Login kopieren

Unter normalen Umständen gibt der Server „ok“ zurück, was bedeutet, dass die Authentifizierungs-Middleware die Weitergabe dieser Anfrage zulässt. Wenn wir jedoch 123456 in andere Werte ändern, kann diese Anfrage die Authentifizierungs-Middleware nicht weitergeben.

Weitere technische Artikel zum Laravel-Framework finden Sie im Tutorial Laravel!

Das obige ist der detaillierte Inhalt vonWie Laravel ApiToken zur Authentifizierung von Anfragen verwendet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:csdn.net
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!