Maison développement back-end tutoriel php Comment rédiger une validation de formulaire sécurisée en utilisant PHP ?

Comment rédiger une validation de formulaire sécurisée en utilisant PHP ?

Aug 26, 2023 pm 08:04 PM
编程 表单验证 php安全

Comment rédiger une validation de formulaire sécurisée en utilisant PHP ?

Comment rédiger une validation de formulaire sécurisée en utilisant PHP ?

在开发Web应用程序时,表单是必不可少的组成部分之一。通过表单,我们可以与用户进行交互,并获取用户输入的数据。但是,用户输入的数据往往不可信,可能包含恶意的代码和恶意的行为。因此,在处理用户输入数据之前,必须对其进行验证和过滤,以确保应用程序的安全性。本文将介绍如何使用PHP编写安全的表单验证。

  1. 开启PHP过滤器

PHP提供了一些内置的过滤器,可用于验证和过滤用户输入数据。首先,我们需要确保PHP的过滤器功能已经开启。在php.ini文件中找到以下代码行,并确保它们没有被注释掉:

;extension=filter
;extension=filter_xss
Copier après la connexion

去掉前面的分号并保存文件,然后重启Web服务器。

  1. 设置表单

首先,我们需要设置表单,定义表单标签和相应的输入字段。例如,创建一个注册表单,包含用户名、密码和电子邮件地址字段:

<form action="register.php" method="post">
    <label for="username">用户名:</label>
    <input type="text" name="username" id="username">

    <label for="password">密码:</label>
    <input type="password" name="password" id="password">

    <label for="email">邮箱:</label>
    <input type="email" name="email" id="email">

    <input type="submit" value="注册">
</form>
Copier après la connexion
  1. 编写验证代码

在表单提交后,我们需要编写验证代码对用户输入数据进行验证和过滤。首先,我们可以使用过滤器函数filter_input()filter_input_array()来获取并过滤用户输入数据。

$username = filter_input(INPUT_POST, 'username', FILTER_SANITIZE_STRING);
$password = filter_input(INPUT_POST, 'password', FILTER_SANITIZE_STRING);
$email = filter_input(INPUT_POST, 'email', FILTER_SANITIZE_EMAIL);
Copier après la connexion

在上述代码中,filter_input()函数用于过滤单个输入字段,filter_input_array()函数用于过滤多个输入字段。FILTER_SANITIZE_STRING用于过滤字符串,FILTER_SANITIZE_EMAIL用于过滤电子邮件地址。

接下来,我们可以使用正则表达式对用户名和密码进行额外的验证。例如,验证用户名只包含字母、数字和下划线,并且长度在3到20个字符之间:

$usernameRegex = '/^[a-zA-Z0-9_]{3,20}$/';
if (!preg_match($usernameRegex, $username)) {
    echo "用户名必须是3到20个字符的字母、数字或下划线组合";
    exit();
}
Copier après la connexion

类似地,我们可以对其他需要进一步验证的字段进行正则表达式验证。

最后,确保在将用户输入数据存储到数据库之前,使用适当的转义函数对数据进行转义,以防止SQL注入攻击。例如,使用mysqli_real_escape_string()函数对数据进行转义:

$username = mysqli_real_escape_string($dbConnection, $username);
$password = mysqli_real_escape_string($dbConnection, $password);
$email = mysqli_real_escape_string($dbConnection, $email);
Copier après la connexion

在上述代码中,$dbConnection是数据库连接对象。

  1. 错误处理

在表单验证过程中,可能会出现一些错误,例如用户名已被占用、密码过弱等。针对这些情况,我们应该提供相应的错误提示。在验证代码中,使用$errors数组来存储错误信息,并在表单中显示这些错误信息:

$errors = array();

// 验证用户名是否已经被占用
if (usernameExists($username)) {
    $errors['username'] = "用户名已经被占用";
}

// 验证密码强度
if (isWeakPassword($password)) {
    $errors['password'] = "密码过弱";
}

// 显示错误信息
if (!empty($errors)) {
    foreach ($errors as $error) {
        echo $error . "<br>";
    }
}
Copier après la connexion

在上述代码中,usernameExists()isWeakPassword()是自定义的验证函数,用于检查用户名是否已被占用和密码是否过弱。

综上所述,通过合理设置表单和编写安全的验证代码,我们可以有效地过滤和验证用户输入数据,提高Web应用程序的安全性。当然,除了前端验证,后端的安全措施也是必不可少的,例如使用预处理语句来防止SQL注入等攻击。

以上就是如何使用PHP编写安全的表单验证的介绍。希望能对你有所帮助!

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)

Supprimez les valeurs en double du tableau PHP à l'aide d'expressions régulières Supprimez les valeurs en double du tableau PHP à l'aide d'expressions régulières Apr 26, 2024 pm 04:33 PM

Comment supprimer les valeurs en double du tableau PHP à l'aide d'expressions régulières : utilisez l'expression régulière /(.*)(.+)/i pour faire correspondre et remplacer les doublons. Parcourez les éléments du tableau et vérifiez les correspondances à l'aide de preg_match. S'il y a une correspondance, ignorez la valeur ; sinon, ajoutez-la à un nouveau tableau sans valeurs en double.

Comment fonctionne le détournement de session et comment pouvez-vous l'atténuer en PHP? Comment fonctionne le détournement de session et comment pouvez-vous l'atténuer en PHP? Apr 06, 2025 am 12:02 AM

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.

A quoi sert la programmation et à quoi sert de l'apprendre ? A quoi sert la programmation et à quoi sert de l'apprendre ? Apr 28, 2024 pm 01:34 PM

1. La programmation peut être utilisée pour développer divers logiciels et applications, notamment des sites Web, des applications mobiles, des jeux et des outils d'analyse de données. Ses domaines d'application sont très larges, couvrant presque tous les secteurs, notamment la recherche scientifique, la santé, la finance, l'éducation, le divertissement, etc. 2. L'apprentissage de la programmation peut nous aider à améliorer nos compétences en résolution de problèmes et nos capacités de réflexion logique. Lors de la programmation, nous devons analyser et comprendre les problèmes, trouver des solutions et les traduire en code. Cette façon de penser peut cultiver nos capacités analytiques et abstraites et améliorer notre capacité à résoudre des problèmes pratiques.

Résolution de problèmes avec Python : débloquez des solutions puissantes en tant que codeur débutant Résolution de problèmes avec Python : débloquez des solutions puissantes en tant que codeur débutant Oct 11, 2024 pm 08:58 PM

Python permet aux débutants de résoudre des problèmes. Sa syntaxe conviviale, sa bibliothèque complète et ses fonctionnalités telles que les variables, les instructions conditionnelles et les boucles permettent un développement de code efficace. De la gestion des données au contrôle du flux du programme et à l'exécution de tâches répétitives, Python fournit

Collection d'énigmes de programmation C++ : stimule la réflexion et améliore les compétences en programmation Collection d'énigmes de programmation C++ : stimule la réflexion et améliore les compétences en programmation Jun 01, 2024 pm 10:26 PM

Les énigmes de programmation C++ couvrent les concepts d'algorithme et de structure de données tels que la séquence de Fibonacci, la factorielle, la distance de Hamming, les valeurs maximales et minimales des tableaux, etc. En résolvant ces énigmes, vous pouvez consolider vos connaissances en C++ et améliorer la compréhension des algorithmes et vos compétences en programmation.

Vulnérabilités de sécurité et solutions dans le développement PHP Vulnérabilités de sécurité et solutions dans le développement PHP May 09, 2024 pm 03:33 PM

Vulnérabilités de sécurité et solutions dans le développement PHP Introduction PHP est un langage de script côté serveur populaire largement utilisé dans le développement Web. Cependant, comme tout logiciel, PHP présente certaines failles de sécurité. Cet article explorera les vulnérabilités de sécurité PHP courantes et leurs solutions. Vulnérabilité de sécurité PHP courante Injection SQL : permet à un attaquant d'accéder ou de modifier les données de la base de données en saisissant du code SQL malveillant dans un formulaire Web ou une URL. Cross-site scripting (XSS) : permet à un attaquant d'exécuter du code de script malveillant dans le navigateur de l'utilisateur. Le fichier contient : permet à un attaquant de charger et d'exécuter des fichiers distants ou des fichiers sensibles sur le serveur. Exécution de code à distance (RCE) : permet aux attaquants d'exécuter des

La clé du codage : libérer la puissance de Python pour les débutants La clé du codage : libérer la puissance de Python pour les débutants Oct 11, 2024 pm 12:17 PM

Python est un langage d'introduction à la programmation idéal pour les débutants grâce à sa facilité d'apprentissage et ses fonctionnalités puissantes. Ses bases incluent : Variables : utilisées pour stocker des données (nombres, chaînes, listes, etc.). Type de données : Définit le type de données dans la variable (entier, virgule flottante, etc.). Opérateurs : utilisés pour les opérations mathématiques et les comparaisons. Flux de contrôle : contrôlez le flux d'exécution du code (instructions conditionnelles, boucles).

Expliquez les scripts croisés (XSS) et comment l'empêcher dans PHP (HTMLSpecialChars). Expliquez les scripts croisés (XSS) et comment l'empêcher dans PHP (HTMLSpecialChars). Apr 08, 2025 am 12:04 AM

XSS est une attaque qui est exécutée dans le navigateur de l'utilisateur en injectant des scripts malveillants. L'utilisation de la fonction HTMLSpecialCars en PHP peut effectivement empêcher les attaques XSS: 1) HTMLSpecialChars convertit des caractères spéciaux en entités HTML pour empêcher les navigateurs de les interpréter comme du code; 2) Lorsque vous utilisez dans les attributs HTML, les guillemets doivent être échappés à l'aide du drapeau ent_quotes; 3) La combinaison d'autres mesures de sécurité, telles que la vérification des entrées et le codage de sortie, une protection à plusieurs niveaux est formée.

See all articles