Maison cadre php Laravel laravel implémente l'enregistrement de connexion

laravel implémente l'enregistrement de connexion

May 20, 2023 pm 09:10 PM

Laravel est un framework PHP populaire qui fournit un environnement de développement puissant qui facilite la création d'applications Web. L'une des fonctionnalités importantes est le système d'authentification propre à Laravel, qui vous permet de mettre en œuvre rapidement l'authentification des utilisateurs, y compris la connexion et l'enregistrement. Dans cet article, nous montrerons comment implémenter l'enregistrement de connexion à l'aide de Laravel.

Environnement de déploiement
Avant de commencer à implémenter l'authentification, nous devons nous assurer que l'environnement Laravel a été configuré et que la connexion à la base de données a été configurée. Si vous n'avez pas encore installé Laravel, vous pouvez vous référer au guide d'installation dans la documentation officielle. Dans l'application Laravel, nous créons la structure de fichiers et de répertoires nécessaire à l'aide de l'outil de ligne de commande Artisan. Dans la ligne de commande, nous pouvons créer une nouvelle application Laravel en utilisant la commande suivante :

composer create-project --prefer-dist laravel/laravel blog

Après la création, naviguez Accédez au répertoire racine de l'application et exécutez la commande suivante pour générer la clé de l'application :

php artisan key:generate

Register Route
In Laravel, les routes sont des connexions Un pont entre les URI et les méthodes de contrôleur correspondantes. Pour enregistrer nos routes d'authentification, nous devons mettre à jour le fichier routes/web.php. Dans ce fichier, nous définissons les itinéraires de l'application, qui incluent les itinéraires de connexion et d'enregistrement.

Tout d'abord, nous devons définir une route qui envoie une requête POST à ​​/register et la lier à la méthode register() de RegisterController. Cela affichera un formulaire d'inscription dans lequel l'utilisateur pourra remplir son nom d'utilisateur et son mot de passe.

Route::post('/register', 'AuthRegisterController@register')->name('register');

Ensuite, nous devons définir l'envoi du POST Demandez une route vers /login et liez-la à la méthode login() du LoginController. Cela affichera un formulaire de connexion dans lequel l'utilisateur pourra remplir son nom de connexion et son mot de passe. Si l'utilisateur ne dispose pas d'informations d'identification valides pour s'authentifier, l'application est redirigée vers le formulaire de connexion.

Route::post('/login', 'AuthLoginController@login')->name('login');

Enfin, nous devons définir tous les éléments protégés routage. Dans Laravel, nous pouvons utiliser le middleware d'authentification pour garantir que l'utilisateur a été authentifié. Ce middleware redirigera automatiquement les utilisateurs non authentifiés vers la route /login.

Route::middleware(['auth'])->group(function () {

// your protected routes go here
Copier après la connexion

});

Contrôle du traitement Contrôleur
Nous avons défini les itinéraires nécessaires et devons maintenant les gérer dans le contrôleur. Dans Laravel, un contrôleur est une classe qui gère une requête HTTP spécifique et les méthodes du contrôleur renvoient des réponses HTTP. Dans l'application, nous devons créer deux contrôleurs pour gérer les demandes d'inscription et de connexion.

Dans le répertoire app/Http/Controllers/Auth, créez deux fichiers, LoginController.php et RegisterController.php. Ces deux fichiers sont les classes de contrôleur fournies avec Laravel. Dans ces contrôleurs, nous devons remplacer les méthodes par défaut de Laravel pour fournir des fonctionnalités personnalisées pour les demandes de connexion et d'enregistrement.

Login Controller
Regardons d'abord le contrôleur LoginController.php. Ce contrôleur contient deux méthodes : showLoginForm() et login(). La méthode

showLoginForm() renvoie la vue du formulaire de connexion (resources/views/auth/login.blade.php), qui contient un formulaire dans lequel l'utilisateur peut saisir son nom de connexion et son mot de passe. Cette méthode est fournie par Laravel. La méthode

public function showLoginForm()
{

return view('auth.login');
Copier après la connexion

}

login() est l'endroit où la logique de connexion est réellement implémentée. Cette méthode reçoit une instance IlluminateHttpRequest et valide les entrées de l'utilisateur à l'aide de la méthode validate() de l'instance. Si la validation du formulaire réussit, Laravel recherchera automatiquement l'utilisateur avec le login et le mot de passe donnés et le connectera à l'application.

public function login(Request $request)
{

$request->validate([
    'email' => 'required|string|email',
    'password' => 'required|string',
    'remember' => 'boolean'
]);

$credentials = $request->only('email', 'password');

if (Auth::attempt($credentials, $request->remember)) {
    return redirect()->intended('dashboard');
}

return redirect()->back()->withInput($request->only('email', 'remember'));
Copier après la connexion

}

Notez que la méthode tentative() sera basée sur les informations d'identification données pour vérifier automatiquement si le mot de passe est correct. Si le mot de passe est incorrect, false sera renvoyé.

Si l'utilisateur s'est authentifié avec succès et que l'URL qu'il a précédemment demandée est stockée (généralement des URL bloquées par un middleware d'authentification), nous pouvons utiliser la fonction d'assistance Laravel destinée() pour le rediriger vers l'URL. Si aucune URL n'est stockée, redirigez vers le tableau de bord frontal (/dashboard).

Register Controller
Ensuite, regardons le contrôleur RegisterController.php. En plus des méthodes par défaut de Laravel, nous devons également implémenter la méthode register(). La méthode

register() est très similaire à la méthode login(). Il reçoit une instance IlluminateHttpRequest et valide les entrées de l'utilisateur à l'aide de la méthode validate() de l'instance. Si la validation du formulaire réussit, Laravel créera un nouvel utilisateur et l'enregistrera dans la base de données. Nous pouvons ensuite utiliser le comportement par défaut de Laravel pour connecter l'utilisateur à l'application.

public function register(Request $request)
{

$request->validate([
    'name' => 'required|string|max:255',
    'email' => 'required|string|email|max:255|unique:users',
    'password' => 'required|string|min:6|confirmed',
]);

$user = User::create([
    'name' => $request->name,
    'email' => $request->email,
    'password' => Hash::make($request->password),
]);

Auth::login($user);

return redirect()->intended('dashboard');
Copier après la connexion

}

Dans le contrôleur d'enregistrement, nous pouvons utiliser la fonction auxiliaire Hash pour chiffrer le mot de passe. Si la vérification du mot de passe réussit, nous créons le nouvel utilisateur et le connectons à l'application.

View Layer
Maintenant que nous avons défini les routes et les contrôleurs nécessaires, nous devons créer la vue d'authentification.

在 resources/views/auth 目录中,我们可以创建 login.blade.php 和 register.blade.php 两个视图文件。这些视图包含登录和注册表单,使用了一些 Laravel 帮助程序,可以处理表单验证并显示错误消息。

登录视图
在 login.blade.php 文件中,我们可以使用 Laravel 的 Form 辅助函数创建登录表单。这个函数会自动为表单添加 CSRF 令牌,并为输入字段编写 HTML 标记。

@csrf

<div class="form-group row">
    <label for="email" class="col-sm-4 col-form-label text-md-right">{{ __('Email Address') }}</label>

    <div class="col-md-6">
        <input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required autofocus>

        @if ($errors->has('email'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('email') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label>

    <div class="col-md-6">
        <input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required>

        @if ($errors->has('password'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('password') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <div class="col-md-6 offset-md-4">
        <div class="form-check">
            <input class="form-check-input" type="checkbox" name="remember" id="remember" {{ old('remember') ? 'checked' : '' }}>

            <label class="form-check-label" for="remember">
                {{ __('Remember Me') }}
            </label>
        </div>
    </div>
</div>

<div class="form-group row mb-0">
    <div class="col-md-8 offset-md-4">
        <button type="submit" class="btn btn-primary">
            {{ __('Login') }}
        </button>

        @if (Route::has('password.request'))
            <a class="btn btn-link" href="{{ route('password.request') }}">
                {{ __('Forgot Your Password?') }}
            </a>
        @endif
    </div>
</div>
Copier après la connexion

注意,我们使用了 Blade 模板引擎的 @csrf 和 @if 语句来生成必要的 CSRF 令牌并显示验证错误。

注册视图
在 register.blade.php 文件中,我们可以使用 Laravel 的 Form 帮助器创建注册表单。这个函数自动为表单添加 CSRF 令牌,并为输入字段编写 HTML 标记。

@csrf

<div class="form-group row">
    <label for="name" class="col-md-4 col-form-label text-md-right">{{ __('Name') }}</label>

    <div class="col-md-6">
        <input id="name" type="text" class="form-control{{ $errors->has('name') ? ' is-invalid' : '' }}" name="name" value="{{ old('name') }}" required autofocus>

        @if ($errors->has('name'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('name') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label>

    <div class="col-md-6">
        <input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required>

        @if ($errors->has('email'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('email') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label>

    <div class="col-md-6">
        <input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required>

        @if ($errors->has('password'))
            <span class="invalid-feedback" role="alert">
                <strong>{{ $errors->first('password') }}</strong>
            </span>
        @endif
    </div>
</div>

<div class="form-group row">
    <label for="password-confirm" class="col-md-4 col-form-label text-md-right">{{ __('Confirm Password') }}</label>

    <div class="col-md-6">
        <input id="password-confirm" type="password" class="form-control" name="password_confirmation" required>
    </div>
</div>

<div class="form-group row mb-0">
    <div class="col-md-6 offset-md-4">
        <button type="submit" class="btn btn-primary">
            {{ __('Register') }}
        </button>
    </div>
</div>
Copier après la connexion

注意,我们使用了 Blade 模板引擎的 @csrf 和 @if 语句来生成必要的 CSRF 令牌并显示验证错误消息。

结论
通过 Laravel 可以快速、方便、安全地实现 Web 应用程序的登录和注册身份验证功能,从而保护您的应用程序免受未授权的访问。在本文中,我们介绍了 Laravel 的身份验证系统并实现了注册和登录。现在,您可以使用这些基础知识构建更完整的用户身份验证系统,或将其集成到您的现有应用程序中。

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le meilleur, Django ou Laravel? Quel est le meilleur, Django ou Laravel? Mar 28, 2025 am 10:41 AM

Django et Laravel sont tous deux des frameworks à pile. Django convient aux développeurs Python et à la logique métier complexe, tandis que Laravel convient aux développeurs PHP et à la syntaxe élégante. 1.Django est basé sur Python et suit la philosophie "Battery-Complete", adaptée au développement rapide et à une grande concurrence. 2.Laravel est basé sur PHP, mettant l'accent sur l'expérience du développeur et convient aux projets de petite et moyenne taille.

Laravel et le backend: alimentation logique d'application Web Laravel et le backend: alimentation logique d'application Web Apr 11, 2025 am 11:29 AM

Comment Laravel joue-t-il un rôle dans la logique backend? Il simplifie et améliore le développement backend par le biais de systèmes de routage, d'éloquente, d'authentification et d'autorisation, d'événements et d'auditeurs et d'optimisation des performances. 1. Le système de routage permet la définition de la structure d'URL et demande la logique de traitement. 2.Lao-éloquente simplifie l'interaction de la base de données. 3. Le système d'authentification et d'autorisation est pratique pour la gestion des utilisateurs. 4. L'événement et l'écoute implémentent la structure de code couplée de manière lâche. 5. L'optimisation des performances améliore l'efficacité de l'application par la mise en cache et la file d'attente.

Quel est le meilleur PHP ou Laravel? Quel est le meilleur PHP ou Laravel? Mar 27, 2025 pm 05:31 PM

PHP et Laravel ne sont pas directement comparables, car Laravel est un cadre basé sur PHP. 1.Php convient aux petits projets ou à un prototypage rapide car il est simple et direct. 2. Laravel convient à de grands projets ou à un développement efficace car il offre des fonctions et des outils riches, mais a une courbe d'apprentissage abrupte et peut ne pas être aussi bon que PHP pur.

Laravel est-il un frontend ou un backend? Laravel est-il un frontend ou un backend? Mar 27, 2025 pm 05:31 PM

LaravelisabackendFrameworkBuiltonPhp, conçue pourwebapplicationdevelopment.itfocusonServer-sidelogic, databasemanagement, andapplicationsstructure, andcanbenegrategratedwithfrontentechnologies likevue.jsorrectForfull-stackdevelopment.

Exemple d'introduction de Laravel Exemple d'introduction de Laravel Apr 18, 2025 pm 12:45 PM

Laravel est un cadre PHP pour la création facile des applications Web. Il fournit une gamme de fonctionnalités puissantes, notamment: Installation: Installez le Laravel CLI globalement avec Composer et créez des applications dans le répertoire du projet. Routage: définissez la relation entre l'URL et le gestionnaire dans Routes / web.php. Voir: Créez une vue dans les ressources / vues pour rendre l'interface de l'application. Intégration de la base de données: fournit une intégration prête à l'emploi avec des bases de données telles que MySQL et utilise la migration pour créer et modifier des tables. Modèle et contrôleur: le modèle représente l'entité de la base de données et le contrôleur traite les demandes HTTP.

Polyvylity de Laravel: des sites simples aux systèmes complexes Polyvylity de Laravel: des sites simples aux systèmes complexes Apr 13, 2025 am 12:13 AM

Le projet de développement de Laravel a été choisi en raison de sa flexibilité et de sa puissance pour répondre aux besoins de différentes tailles et complexités. Laravel fournit un système de routage, Eloquentorm, une ligne de commande artisanale et d'autres fonctions, soutenant le développement de blogs simples aux systèmes complexes au niveau de l'entreprise.

Comment apprendre Laravel comment apprendre Laravel gratuitement Comment apprendre Laravel comment apprendre Laravel gratuitement Apr 18, 2025 pm 12:51 PM

Vous voulez apprendre le cadre de Laravel, mais ne souffrez pas de ressources ni de pression économique? Cet article vous fournit un apprentissage gratuit de Laravel, vous apprenant à utiliser des ressources telles que les plateformes en ligne, les documents et les forums communautaires pour jeter une base solide pour votre parcours de développement PHP de la mise en place de maîtrise.

Pourquoi Laravel est-il si populaire? Pourquoi Laravel est-il si populaire? Apr 02, 2025 pm 02:16 PM

La popularité de Laravel comprend son processus de développement simplifié, offrant un environnement de développement agréable et des caractéristiques riches. 1) Il absorbe la philosophie de conception des rubyonrails, combinant la flexibilité de PHP. 2) Fournir des outils tels que l'éloquente, le moteur de modèle de lame, etc. pour améliorer l'efficacité du développement. 3) Son mécanisme d'architecture MVC et d'injection de dépendance rend le code plus modulaire et testable. 4) fournit des outils de débogage puissants et des méthodes d'optimisation des performances telles que les systèmes de mise en cache et les meilleures pratiques.

See all articles