Maison développement back-end tutoriel php Implémenter la vérification de sécurité PHP à l'aide de Laravel Fortify

Implémenter la vérification de sécurité PHP à l'aide de Laravel Fortify

Jul 24, 2023 pm 07:07 PM
php laravel fortify

Utilisez Laravel Fortify pour implémenter la vérification de sécurité PHP

Introduction :
Avec l'application généralisée d'Internet, les problèmes de sécurité des réseaux sont devenus de plus en plus importants. Lors de la création et du développement d’applications Web, la sécurité des informations des utilisateurs est une priorité essentielle. Afin de renforcer la vérification de sécurité PHP, nous pouvons utiliser Laravel Fortify, un outil puissant pour simplifier et renforcer notre processus de vérification. Cet article présentera les concepts de base et l'utilisation de Laravel Fortify, et fournira des exemples de code pour aider les lecteurs à mieux comprendre.

  1. Introduction à Laravel Fortify
    Laravel Fortify est un package PHP officiellement fourni qui fournit un système d'authentification moderne pour le framework Laravel. Fortify fournit une série de fonctions d'authentification prédéfinies, notamment l'enregistrement, la connexion, la réinitialisation du mot de passe, la vérification des e-mails, etc., qui peuvent nous aider à créer rapidement des fonctions d'authentification des utilisateurs sûres et fiables. Dans le même temps, Fortify intègre également d'autres fonctionnalités, telles que la vérification en deux étapes, la limitation du nombre de tentatives de connexion, etc., pour offrir une sécurité plus complète.
  2. Installez Laravel Fortify
    Tout d'abord, assurez-vous d'avoir installé le framework Laravel. Ensuite, basculez vers le répertoire de votre projet dans le terminal et exécutez la commande suivante pour installer Laravel Fortify :
composer require laravel/fortify
Copier après la connexion

Une fois l'installation terminée, nous devons exécuter la commande suivante pour générer le fichier de configuration Fortify :

php artisan vendor:publish --provider="LaravelFortifyFortifyServiceProvider"
Copier après la connexion

Le fichier de configuration sera généré Sous config/fortify.php, nous pouvons faire quelques configurations personnalisées ici. config/fortify.php 下,我们可以在这里进行一些自定义配置。

  1. 基本使用
    在配置完成后,我们就可以开始使用 Laravel Fortify 了。首先,在你的应用程序中引入 Fortify 的一些基本配置和路由:
// routes/web.php

use LaravelFortifyFortify;

// 引入 Fortify 的一些基本配置
Fortify::loginView(function () {
    return view('auth.login');
});

// 引入 Fortify 的路由
Fortify::authenticateUsing(function (Request $request) {
    // 用户验证逻辑
});

// 用户认证相关路由
Route::group(['middleware' => config('fortify.middleware', ['web'])], function () {
    // 注册、登录、密码重置、邮箱验证等路由
    Fortify::registerRoutes();
    Fortify::resetPasswordRoutes();
    Fortify::verifyEmailRoutes();
});
Copier après la connexion

这里的基本配置包括了用户登录界面的视图和用户验证逻辑。Fortify 提供了一些预设的视图模板,你可以根据需求进行修改或者自定义。

  1. 自定义用户认证逻辑
    在上面的示例代码中,我们提到了用户验证逻辑的部分。这里,我们可以通过实现 Laravel Fortify 的 authenticateUsing 方法来自定义用户的认证方式。下面是一个简单的例子:
// routes/web.php

use LaravelFortifyFortify;
use IlluminateSupportFacadesAuth;

Fortify::authenticateUsing(function (Request $request) {
    // 获取表单提交的登录信息
    $credentials = $request->only('email', 'password');

    // 用户认证逻辑
    if (Auth::attempt($credentials)) {
        return redirect()->intended('/dashboard');
    } else {
        return back()->withErrors([
            'email' => 'Email 或密码不正确',
        ]);
    }
});
Copier après la connexion

这个例子中,我们使用了 Laravel 的 Auth Facade 来进行用户认证。你可以根据你的应用程序需求,使用不同的用户认证方式。

  1. 其他功能
    除了基本的认证功能,Laravel Fortify 还提供了一些其他的安全功能。这些功能可以在 config/fortify.php 文件中进行配置。下面是一些常用功能的示例:
  • 两步验证:使用 Laravel 的 TwoFactorAuthentication 中间件来开启两步验证:

    Fortify::authenticateThrough(function (Request $request) {
      return array_filter([
          config('fortify.limiters.login') ? null : RateLimiter::for('login'),
          $request->input('remember') ? null : ThrottleFailedLogins::forUser($request->user()),
          TwoFactorAuthentication::check($request) ? null : PreventsTwoFactorAuthentication::class,
      ]);
    });
    Copier après la connexion
  • 限制登录尝试次数:可以在 config/fortify.php 中配置登录尝试次数和锁定时间:

    'limiters' => [
      'login' => [
          'enabled' => true,
          'tries' => 5,
          'lockout_time' => 300,
      ],
    ],
    Copier après la connexion
  • Email 验证:Fortify 提供了一整套预先构建好的路由来处理邮箱验证相关的逻辑,你可以在 config/fortify.php
    1. Utilisation de baseUne fois la configuration terminée, nous pouvons commencer à utiliser Laravel Fortify. Tout d'abord, introduisez une configuration de base et un routage de Fortify dans votre application :


      rrreee

      La configuration de base ici inclut la vue de l'interface de connexion utilisateur et la logique d'authentification de l'utilisateur. Fortify fournit des modèles de vues prédéfinis que vous pouvez modifier ou personnaliser en fonction de vos besoins. 🎜
        🎜Logique d'authentification utilisateur personnalisée🎜Dans l'exemple de code ci-dessus, nous avons mentionné la partie logique d'authentification utilisateur. Ici, nous pouvons personnaliser la méthode d'authentification de l'utilisateur en implémentant la méthode authenticateUsing de Laravel Fortify. Voici un exemple simple : 🎜🎜rrreee🎜Dans cet exemple, nous utilisons la façade Auth de Laravel pour l'authentification des utilisateurs. Vous pouvez utiliser différentes méthodes d'authentification utilisateur en fonction des besoins de votre application. 🎜
          🎜Autres fonctionnalités🎜En plus des fonctions d'authentification de base, Laravel Fortify fournit également d'autres fonctionnalités de sécurité. Ces fonctionnalités peuvent être configurées dans le fichier config/fortify.php. Voici quelques exemples de fonctionnalités couramment utilisées : 🎜🎜
        🎜🎜Vérification en deux étapes : utilisez le middleware TwoFactorAuthentication de Laravel pour activer la vérification en deux étapes : 🎜rrreee🎜🎜🎜Limiter le nombre de tentatives de connexion : Vous pouvez configurer le nombre de tentatives de connexion et le temps de verrouillage dans config/fortify.php : 🎜rrreee🎜🎜Vérification des e-mails : Fortify fournit un ensemble de routes prédéfinies pour gérer la logique liée à la vérification des e-mails, vous peut config/fortify.php. 🎜🎜🎜Conclusion : 🎜En utilisant Laravel Fortify, nous pouvons facilement créer et renforcer notre processus de vérification de sécurité PHP. Cet article présente les concepts de base et l'utilisation de Laravel Fortify, et fournit des exemples de code pour aider les lecteurs à mieux comprendre. Nous espérons que ces informations vous aideront à mieux protéger la sécurité des informations de vos utilisateurs et à accroître la fiabilité de vos applications Web. 🎜

      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

    AI Hentai Generator

    AI Hentai Generator

    Générez AI Hentai gratuitement.

    Article chaud

    R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
    4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Meilleurs paramètres graphiques
    4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Comment réparer l'audio si vous n'entendez personne
    4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25: Comment déverrouiller tout dans Myrise
    1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

    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)

    Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

    PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

    Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

    Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

    Comment analysez-vous et traitez-vous HTML / XML dans PHP? Comment analysez-vous et traitez-vous HTML / XML dans PHP? Feb 07, 2025 am 11:57 AM

    Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

    Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Apr 05, 2025 am 12:04 AM

    JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

    Programme PHP pour compter les voyelles dans une chaîne Programme PHP pour compter les voyelles dans une chaîne Feb 07, 2025 pm 12:12 PM

    Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

    Expliquez la liaison statique tardive en PHP (statique: :). Expliquez la liaison statique tardive en PHP (statique: :). Apr 03, 2025 am 12:04 AM

    Liaison statique (statique: :) ​​implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

    Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Apr 03, 2025 am 12:03 AM

    Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.

    Comment obtenir le code de retour lorsque l'envoi par e-mail échoue à Laravel? Comment obtenir le code de retour lorsque l'envoi par e-mail échoue à Laravel? Apr 01, 2025 pm 02:45 PM

    Méthode pour obtenir le code de retour lorsque l'envoi par e-mail de Laravel échoue. Lorsque vous utilisez Laravel pour développer des applications, vous rencontrez souvent des situations où vous devez envoyer des codes de vérification. Et en réalité ...

    See all articles