Maison  >  Article  >  développement back-end  >  Saisie et vérification du formulaire d'apprentissage du formulaire PHP

Saisie et vérification du formulaire d'apprentissage du formulaire PHP

WBOY
WBOYoriginal
2021-10-29 10:38:575272parcourir

Dans l'article précédent, je vous ai présenté "Comment définir et obtenir les attributs PDO dans l'apprentissage des bases de données PHP ?" 》, qui présente en détail les connaissances pertinentes sur la façon de définir et d'obtenir les attributs PDO en PHP. Dans cet article, nous examinerons les problèmes liés aux formulaires PHP. J'espère que cela sera utile à tout le monde !

Saisie et vérification du formulaire d'apprentissage du formulaire PHP

Dans l'article précédent, nous avons déjà compris les bases de PHP, notamment les variables $_GET et $_POST, qui servent à récupérer des informations dans le form , les points de connaissance qui nécessitent notre attention sont la saisie utilisateur du formulaire PHP et la validation du formulaire. Jetons ensuite un coup d'œil aux connaissances connexes sur la saisie et la validation de formulaire en PHP.
$_GET $_POST 变量,它们用来检索表单中的信息,其中需要我们注意的知识点就是PHP表单用户输入和表单验证。那接下来我们就来看一下PHP中表单输入与表单验证的相关知识吧。

PHP表单和用户输入

想要去了解PHP表单和用户输入,首先我们要明白什么是表单。Web表单准确来说算是一个互动平台,主要的功能就是让浏览者和网站有一个互动的平台。表单主要就是在网页中用来发送数据到服务器。

例如,注册信息时使用到的表单,当你填写完信息时需要提交,这时候提交就是将你注册时表单上的内容从客户端浏览器传送到服务器端,再经过PHP程序进行处理后,再将用户所需要的信息传递回到客户端浏览器上,通过获取用户的信息,使得PHP与Web表单实现交互。就是提供了这么一个互动的平台。

接下来我们通过示例来看一下表单,示例如下:

<!DOCTYPE html>
 <html lang="en">
 <head>
     <meta charset="UTF-8">
     <title>PHP中文网</title>
 </head>
 <body>
 
 <form action="form.php" method="post">
     名字: <input type="text" name="fname"><br>
     年龄: <input type="text" name="age"><br>
     <input type="submit" value="提交">
 </form>
 
 </body>
 </html>

其中需要我们注意的是表单属于HTML的知识,更多的相关知识,大家可以点击《HTML教程》进行学习,上述示例的运行结果:

Saisie et vérification du formulaire dapprentissage du formulaire PHP

这便是我们所说的表单,那么我们在其中填写的信息也就是表单信息会发送到哪里呢?当我们点击提交的时候,表单中的数据就会以POST的形式,发送到form.php这个页面。

<?php
 header("Content-type:text/html;charset=utf-8");    //设置编码
 echo "欢迎你:".$_POST["fname"] ."<br/>";
 echo "你的年龄是:".$_POST[&#39;age&#39;];
 ?>

我们发送到from.php的运行结果如下:

Saisie et vérification du formulaire dapprentissage du formulaire PHP

当用户输入完成后,这时候就需要对表单进行验证了,应该在任何可能的时候通过客户端脚本对用户输入进行验证。浏览器验证速度更快,并且可以减轻服务器的负载。

如果用户输入需要插入数据库,您应该考虑使用服务器验证。在服务器验证表单的一种好的方式是,把表单传给它自己,而不是跳转到不同的页面。这样用户就可以在同一张表单页面得到错误信息。用户也就更容易发现错误了。那么接下来我们一起来看一下表单验证的相关知识吧。

PHP表单验证

在处理PHP表单时我们需要考虑安全性。我们将展示PHP表单数据安全处理,为了防止黑客及垃圾信息我们需要对表单进行数据安全验证。接下来我们通过实例来看一下表单中的必须与可选文本字段,单选按钮,及提交按钮。

示例如下:

<!DOCTYPE HTML>
 <html>
 <head>
     <meta charset="utf-8">
     <title>PHP.cn</title>
 </head>
 <body>
 <h2>PHP 表单验证实例</h2>
 <form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>"> 
    名字: <input type="text" name="name" value="">
     <br>
     E-mail: <input type="text" name="email" value="">
     <br>
     网址: <input type="text" name="website" value="">
     <br>
     备注: <textarea name="comment" rows="5" cols="40"></textarea>
     <br>
     性别:
     <input type="radio" name="gender"  value="female">女
     <input type="radio" name="gender"  value="male">男
     <br>
     <input type="submit" name="submit" value="提交">
 </form>
 </body>
 </html>

输出结果:

Saisie et vérification du formulaire dapprentissage du formulaire PHP

其中我们需要注意的是不同的字段有不同的验证规则,上述示例中不同字段的验证规则如下:

名字的验证规则是必须的,并且只能包含字母和空格。E-mail的验证规则是必须的,其中必须是一个有效的电子邮件地址(包含'@'和'.')。网址的验证规则的是可选的,并且如果存在,它必须包含一个有效的URL。备注的验证规则是可选的,多行输入字段。性别的验证规则是必须的,必须选择一个。

通过上述示例我们再来看一下其中用到的知识:

<span style="font-size: 16px;"><strong>$_SERVER["PHP_SELF"] </strong></span>变量

$_SERVER["PHP_SELF"]是一种超全局变量,它返回当前执行脚本的文件名。因此,$_SERVER["PHP_SELF"] 将表单数据发送到页面本身,而不是跳转到另一张页面。这样,用户就能够在表单页面获得错误提示信息。

<strong><span style="font-size: 16px;">htmlspecialchars()</span></strong>Formulaires PHP et saisie utilisateur

🎜Pour comprendre les formulaires PHP et la saisie utilisateur, nous devons d'abord comprendre ce qu'est un formulaire . Pour être précis, un formulaire Web est une plate-forme interactive et sa fonction principale est de fournir une plate-forme interactive entre les téléspectateurs et le site Web. Les formulaires sont principalement utilisés dans les pages Web pour envoyer des données au serveur. 🎜🎜Par exemple, le formulaire utilisé lors de l'enregistrement des informations doit être soumis lorsque vous remplissez les informations à ce moment-là. La soumission consiste à transférer le contenu du formulaire lorsque vous vous inscrivez du navigateur client au serveur, puis à le traiter via. le programme PHP, puis transférez les informations requises par l'utilisateur vers le navigateur client et permettez à PHP d'interagir avec le formulaire Web en obtenant les informations de l'utilisateur. Il fournit simplement une telle plate-forme interactive. 🎜🎜Ensuite, examinons le formulaire à travers un exemple. L'exemple est le suivant :
🎜
<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">
🎜Ce à quoi nous devons faire attention, c'est que le formulaire appartient au HTML. Pour plus de connaissances connexes, vous pouvez. cliquez sur "Tutoriel HTML🎜" pour étudier les résultats de l'exemple ci-dessus :
🎜🎜Saisie et vérification du formulaire dapprentissage du formulaire PHP🎜🎜Ceci est ce que nous appelons le formulaire, alors nous Où les informations renseignées, c'est-à-dire les informations du formulaire seront-elles envoyées ? Lorsque nous cliquons sur Soumettre, les données du formulaire seront envoyées à la page form.php sous forme de POST. 🎜
<form method="post" action="test_form.php/"><script>alert(&#39;hacked&#39;)</script>">
🎜Les résultats que nous avons envoyés à from.php sont les suivants :
🎜🎜Saisie et vérification du formulaire dapprentissage du formulaire PHP🎜🎜Une fois la saisie de l'utilisateur terminée, le formulaire doit être vérifié à ce moment-là. La saisie de l'utilisateur doit être vérifiée via le script client dans la mesure du possible. La validation du navigateur est plus rapide et réduit la charge sur le serveur. 🎜🎜Si les entrées utilisateur doivent être insérées dans une base de données, vous devriez envisager d'utiliser la validation du serveur. Un bon moyen de valider un formulaire sur le serveur est de se transmettre le formulaire à lui-même, plutôt que de passer à une autre page. De cette façon, les utilisateurs peuvent recevoir des messages d’erreur sur la même page de formulaire. Il sera plus facile pour les utilisateurs de trouver les erreurs. Jetons donc un coup d'œil aux connaissances connexes en matière de validation de formulaire. 🎜🎜🎜Validation des formulaires PHP 🎜🎜
🎜🎜Nous devons prendre en compte la sécurité lors du traitement des formulaires PHP. Nous démontrerons le traitement sécurisé des données du formulaire PHP. Afin de prévenir les pirates informatiques et le spam, nous devons effectuer une vérification de la sécurité des données sur le formulaire. Examinons ensuite les champs de texte obligatoires et facultatifs, les boutons radio et les boutons de soumission du formulaire à travers des exemples. 🎜🎜L'exemple est le suivant :
🎜

 
 
     
     PHP中文网(php.cn)
 
 
 
 
 
 

PHP 表单验证实例

<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>"> 名字:

E-mail:

网址:

备注:

性别:

您输入的内容是:"; echo $name; echo "
"; echo $email; echo "
"; echo $website; echo "
"; echo $comment; echo "
"; echo $gender; ?>
🎜Résultat de sortie :
🎜🎜Saisie et vérification du formulaire dapprentissage du formulaire PHP🎜🎜Ce à quoi nous devons faire attention, c'est que différents champs ont des règles de validation différentes. Les règles de validation pour différents champs dans l'exemple ci-dessus sont les suivantes :
🎜🎜Les règles de validation du nom sont obligatoires et ne peuvent contenir que des lettres et des espaces. La règle de validation E-mail est requise, qui doit être une adresse e-mail valide (contenant '@' et '.'). La règle de validation d'URL est facultative et si elle est présente, elle doit contenir une URL valide. Les règles de validation pour les notes sont des champs de saisie facultatifs sur plusieurs lignes. Une règle de validation du genre est requise et une doit être sélectionnée. 🎜🎜 Jetons un coup d'œil aux connaissances utilisées dans l'exemple ci-dessus : 🎜🎜🎜🎜$_SERVER["PHP_SELF"] 🎜🎜🎜🎜Variables🎜🎜🎜🎜$_SERVER["PHP_SELF " "] est une variable superglobale qui renvoie le nom de fichier du script en cours d'exécution. Par conséquent, $_SERVER["PHP_SELF"] envoie les données du formulaire à la page elle-même, plutôt que de passer à une autre page. De cette manière, les utilisateurs peuvent obtenir des informations sur les messages d'erreur sur la page du formulaire. 🎜🎜🎜🎜htmlspecialchars()🎜🎜🎜🎜 fonction🎜🎜🎜

htmlspecialchars() 函数把特殊字符转换为 HTML 实体。这意味着 之类的 HTML 字符会被替换为 92d33664ec5f827b86e068a341370a86 。这样可防止攻击者通过在表单中注入 HTML 或 JavaScript 代码(跨站点脚本攻击)对代码进行利用。

其中我们需要注意的是:

$_SERVER["PHP_SELF"] 变量能够被黑客利用,如何避免 $_SERVER["PHP_SELF"] 被利用?

$_SERVER["PHP_SELF"] 可以通过 htmlspecialchars() 函数来避免被利用。

form 代码如下所示:

<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">

htmlspecialchars() 把一些预定义的字符转换为 HTML 实体。现在如果用户想利用 PHP_SELF 变量, 结果将输出如下所示:

<form method="post" action="test_form.php/"><script>alert(&#39;hacked&#39;)</script>">

尝试该漏洞失败!

通过PHP验证表单数据

我们要做的第一件事是通过 PHP 的 htmlspecialchars() 函数传递所有变量。在用户提交该表单时,我们还要做两件事:

首先通过 PHP trim() 函数去除用户输入数据中不必要的字符,比如多余的空格、制表符、换行等,然后通过 PHP stripslashes() 函数删除用户输入数据中的反斜杠(\)。接下来我们创建一个检查函数,我们把函数命名为 test_input()。最后我们能够通过 test_input() 函数检查每个 $_POST 变量。

我们将验证程序可以放到上述示例中去,示例如下:


 
 
     
     PHP中文网(php.cn)
 
 
 
 
 
 

PHP 表单验证实例

<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>"> 名字:

E-mail:

网址:

备注:

性别:

您输入的内容是:"; echo $name; echo "
"; echo $email; echo "
"; echo $website; echo "
"; echo $comment; echo "
"; echo $gender; ?>

输出结果:

Saisie et vérification du formulaire dapprentissage du formulaire PHP

其中我们需要注意的是:

我们在执行以上脚本时,会通过$_SERVER["REQUEST_METHOD"]来检测表单是否被提交 。如果 REQUEST_METHOD 是 POST, 表单将被提交 - 数据将被验证。如果表单未提交将跳过验证并显示空白。在以上实例中使用输入项都是可选的,即使用户不输入任何数据也可以正常显示。

大家如果感兴趣的话,可以点击《PHP视频教程》进行更多关于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:
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