DEV Community

Cover image for Améliorez la sécurité de Laravel grâce à des pratiques éprouvées.
Hamza Sehouli
Hamza Sehouli

Posted on

Améliorez la sécurité de Laravel grâce à des pratiques éprouvées.

Dans le domaine de la technologie, nous sommes toujours préoccupés par la sécurité et la façon de repousser les attaquants et les escrocs.
En ce qui concerne Laravel, la protection d'une application implique la mise en œuvre de diverses pratiques de sécurité pour contrecarrer les menaces courantes. Dans cet article, nous allons aborder quelques pratiques de sécurité pour les applications Laravel afin de réduire les risques à presque zéro :

Input Validation :

Les formes sont la partie la plus vulnérable de toute application web, la validation de données de l'utilisateur est cruciale pour prévenir l'injection SQL, XSS et d'autres vulnérabilités.

Pour s'assurer que les données soumises par les utilisateurs sont sécurisées et répondent aux critères spécifiés, Laravel fournit un système de validation robuste pour vérifier les données des requêtes entrantes. Voici un guide plus détaillé sur la validation des entrées dans Laravel :

public function store(Request $request): mixed {
    $validated = $request->validate([
        'name' => 'required|string|max:255',
        'email' => 'required|email|unique:users|max:255',
        'password' => 'required|min:8|confirmed',
    ]);
}

Enter fullscreen mode Exit fullscreen mode

Chaque fois que vous essayez d'obtenir les entrées de la requête et de les remplir dans la base de données, il est fortement recommandé d'éviter d'utiliser $request->all() et d'utiliser à la place un nom de données spécifique par exemple $request->input('phone') ou $request->only(['name', 'email]) pour exclure les données non désirées.

Limiter l'accès :

Il existe plusieurs façons de restreindre l'accès à une application Laravel :

Authentification : Laravel est doté d'un service intégré d'authentification des utilisateurs. Vous pouvez restreindre l'accès à certaines parties de votre site aux utilisateurs connectés en utilisant

Illuminate\Support\Facades\Auth;

if (Auth::check()) {
    // L'utilisateur est connecté.
}
Enter fullscreen mode Exit fullscreen mode

et dans le Blade:

@auth
    // L'utilisateur est authentifié.
@endauth
Enter fullscreen mode Exit fullscreen mode

Middleware : L'option middleware de Laravel fournit un mécanisme pratique pour filtrer les requêtes HTTP entrant dans votre application. Par exemple, Laravel inclut un middleware qui vérifie que l'utilisateur de votre application est authentifié.

Limitation du nombre de requêtes : Vous pouvez limiter le nombre de requêtes qu'un utilisateur peut effectuer dans un laps de temps donné. Laravel offre des fonctionnalités de limitation de trafic prêtes à l'emploi.

CORS : CORS est un moyen qui vous permet de faire une requête pour de nombreuses ressources d'une page web (par exemple des scripts, des images, des polices, etc.) à partir d'un domaine autre que celui d'où provient la ressource. Vous pouvez restreindre l'accès à votre API dans le fichier de configuration cors.php.

Protégez-vous contre les injections SQL :

Utilisez le constructeur de requêtes de Laravel ou l'ORM Eloquent pour prévenir les attaques par injection SQL.

Logging (journalisation et surveillance) :
Afin de garder une trace de ce qui se passe dans votre application, Laravel fournit de puissants services de journalisation qui vous permettent d'enregistrer des messages dans des fichiers, dans le journal des erreurs du système, et même sur Slack, Telegram.

Top comments (0)