Heim >PHP-Framework >Laravel >Laravel-Login-Implementierung

Laravel-Login-Implementierung

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2023-05-29 09:15:37815Durchsuche

Laravel ist ein beliebtes PHP-Framework, das viele leistungsstarke Tools und Funktionen bietet, die Entwicklern beim einfachen Erstellen von WEB-Anwendungen helfen. Unter anderem ist die Implementierung der Login-Funktion ein wichtiger Schritt bei der Entwicklung von Anwendungen. In diesem Artikel wird erläutert, wie die Anmeldefunktion in Laravel implementiert wird.

  1. Laravel installieren

Laravel kann über Composer, ein PHP-Abhängigkeitsverwaltungstool, installiert werden. Um Composer zu installieren, geben Sie den folgenden Befehl ein:

curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer

Nach Abschluss der Installation verwenden Sie den folgenden Befehl, um die Laravel-Anwendung zu erstellen.

composer create-project --prefer-dist laravel/laravel projectname
  1. Datenbankkonfiguration

Bevor Sie das Authentifizierungssystem von Laravel verwenden, müssen Sie die Datenbank konfigurieren. Öffnen Sie die Datei .env und ändern Sie die Datenbankverbindungseinstellungen im folgenden Beispiel. .env 文件,更改以下示例中的数据库连接设置。

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=mydatabase
DB_USERNAME=root
DB_PASSWORD=
  1. 生成用户认证系统

运行以下命令生成 Laravel 的用户认证系统。

php artisan make:auth

这将创建一个用户注册、登录和注销的基本视图和控制器。

  1. 创建用户模型

接下来,需要创建一个用户模型,Laravel默认提供的用户模型是AppUser,可以使用以下命令创建。

php artisan make:model User
  1. 注册和登录验证

注册验证:

public function store(Request $request)
{
    $this->validate($request, [
        'name' => 'required',
        'email' => 'required|email|unique:users,email',
        'password' => 'required|min:6|confirmed',
    ]);
    $user = User::create([
        'name' => $request['name'],
        'email' => $request['email'],
        'password' => bcrypt($request['password']),
    ]);
    Auth::login($user);
    return redirect()->route('dashboard');
}

登录验证:

public function login(Request $request)
{
    $this->validate($request, [
        'email' => 'required|email',
        'password' => 'required|min:6',
    ]);
    $credentials = [
        'email' => $request['email'],
        'password' => $request['password'],
    ];
    if (Auth::attempt($credentials)) {
        return redirect()->intended('dashboard');
    } else {
        return redirect()->back()->withInput($request->only('email', 'remember'));
    }
}

以上代码中,attempt方法将验证用户凭据,如果通过验证,将会将用户状态通过session保存,并且可以使用Auth::check方法检查用户是否已登录。

  1. 中间件

中间件提供了对应用程序的进一步控制和保护。Laravel已经预定义了许多中间件,包括验证用户是否登录的中间件。

在应用程序中添加认证中间件,并将其应用于需要保护的路由:

Route::middleware(['auth'])->group(function () {
    Route::get('/dashboard', 'DashboardController@index')->name('dashboard');
});
  1. 强制使用 HTTPS

在Laravel中,可以轻松地将应用程序强制使用HTTPS:

.env中添加以下行:

APP_ENV=production
APP_URL=https://example.com

然后,打开AppServiceProvider

public function boot()
{
    if (config('app.env') === 'production') {
        URL::forceScheme('https');
    }
}

    Benutzerauthentifizierungssystem generieren

      Führen Sie den folgenden Befehl aus, um das Benutzerauthentifizierungssystem von Laravel zu generieren.
    1. rrreee
    2. Dadurch wird eine grundlegende Ansicht und ein Controller für die Benutzerregistrierung, Anmeldung und Abmeldung erstellt.

      Benutzermodell erstellen

      🎜🎜Als nächstes müssen Sie ein Benutzermodell erstellen, das standardmäßig von Laravel bereitgestellt wird und mit dem erstellt werden kann folgenden Befehl. 🎜rrreee
        🎜Registrierung und Anmeldeüberprüfung🎜🎜🎜Registrierungsüberprüfung: 🎜rrreee🎜Anmeldeüberprüfung: 🎜rrreee🎜Im obigen Code überprüft die Methode attempt die Benutzeranmeldeinformationen , wenn übergeben Zur Überprüfung wird der Benutzerstatus während der Sitzung gespeichert und die Methode Auth::check kann verwendet werden, um zu überprüfen, ob der Benutzer angemeldet ist. 🎜
          🎜Middleware🎜🎜🎜Middleware bietet weitere Kontrolle und Schutz von Anwendungen. Laravel verfügt über viele vordefinierte Middlewares, einschließlich Middleware zur Überprüfung, ob der Benutzer angemeldet ist. 🎜🎜Fügen Sie Ihrer Anwendung Authentifizierungs-Middleware hinzu und wenden Sie sie auf die Routen an, die geschützt werden müssen: 🎜rrreee
            🎜HTTPS erzwingen 🎜🎜🎜In Laravel ist es einfach, Ihre Anwendung zur Verwendung von HTTPS HTTPS zu zwingen : 🎜🎜Fügen Sie die folgende Zeile in .env hinzu: 🎜rrreee🎜Öffnen Sie dann die Klasse AppServiceProvider und fügen Sie die folgende Zeile hinzu: 🎜rrreee🎜Dadurch wird die URL der Anwendung erzwungen Der Link wird in das HTTPS-Protokoll konvertiert. 🎜🎜🎜Zusammenfassung🎜🎜🎜In diesem Artikel wurde bisher die Implementierung der Anmeldefunktion in Laravel vorgestellt, einschließlich der Installation von Laravel, der Konfiguration der Datenbank, der Generierung eines Benutzerauthentifizierungssystems, der Erstellung eines Benutzermodells, der Registrierung und Anmeldeüberprüfung, Middleware und Erzwingung die Verwendung von HTTPS. Wenn Sie die in diesem Artikel beschriebenen Schritte zur Implementierung der Anmeldefunktion von Laravel verwenden, können Sie sicherere und funktionsreichere Anwendungen erstellen. 🎜

Das obige ist der detaillierte Inhalt vonLaravel-Login-Implementierung. 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
Vorheriger Artikel:Laravel ändert das ZeitformatNächster Artikel:Laravel ändert das Zeitformat