Maison >développement back-end >tutoriel php >Approche correcte de la validation des entrées PHP
Méthode de vérification des entrées PHP : utilisez les fonctions intégrées PHP (filter_var, preg_match), utilisez des expressions régulières (telles que vérifier la force du mot de passe), utilisez des listes blanches ou des listes noires (limiter ou interdire des valeurs d'entrée spécifiques)
Vérification des entrées PHP est une pratique correcte
La validation des entrées est cruciale dans les applications Web car elle empêche les entrées malveillantes ou invalides de nuire à l'application. PHP fournit une variété de fonctions et de techniques intégrées pour valider efficacement les entrées.
1. Utilisez les fonctions intégrées de PHP
PHP a intégré plusieurs fonctions utiles pour filtrer et valider les entrées, telles que :
// 过滤用户输入中的 HTML 标记 $filtered_input = filter_var($_POST['input'], FILTER_SANITIZE_SPECIAL_CHARS); // 验证电子邮件地址 $is_email_valid = filter_var($_GET['email'], FILTER_VALIDATE_EMAIL);
2 Utiliser des expressions régulières
Les expressions régulières sont un modèle puissant, peut être utilisé pour valider une entrée complexe. Voici comment vérifier la force du mot de passe à l'aide d'expressions régulières :
function validate_password($password) { $regex = '/^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[!@#$%^&*]).{8,}$/'; return preg_match($regex, $password); }
3. Utilisez la liste blanche ou la liste noire
Si l'entrée contient des valeurs autorisées ou non autorisées, vous pouvez utiliser la liste blanche ou la liste noire pour vérifier.
Liste blanche : Autoriser uniquement le passage de valeurs spécifiques. Par exemple, le code suivant permet uniquement de saisir des fruits spécifiques :
$allowed_fruits = array('apple', 'banana', 'orange'); if (in_array($_GET['fruit'], $allowed_fruits)) { // 输入有效 }
Liste noire : interdit le passage de valeurs spécifiques. Par exemple, le code suivant interdit la saisie contenant des mots-clés spécifiques :
$disallowed_keywords = array('spam', 'malware', 'virus'); if (stripos($_POST['comment'], $disallowed_keywords) !== false) { // 输入无效 }
Exemple réel : formulaire d'inscription d'utilisateur
Voici un exemple de code pour un formulaire d'inscription d'utilisateur qui montre comment utiliser la validation d'entrée PHP :
<?php // 验证用户输入 $errors = array(); if (empty($_POST['username'])) { $errors[] = '用户名不能为空'; } if (!filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) { $errors[] = '无效的电子邮件地址'; } if (!validate_password($_POST['password'])) { $errors[] = '密码强度不足'; } // 处理已验证的输入 if (empty($errors)) { // 注册用户 } ?>
En suivant ces pratiques, vous pouvez valider efficacement les entrées des utilisateurs et garantir la sécurité et l’intégrité de votre application.
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!