La validation des e-mails en PHP est l'une des exigences courantes dans le développement de sites Web. Une vérification efficace des e-mails améliore la précision des saisies des utilisateurs et empêche les enregistrements malveillants et les fuites d'informations. Cet article explique comment utiliser PHP pour écrire un code de vérification d'e-mail simple et efficace afin de garantir que le format d'e-mail saisi par l'utilisateur est conforme à la spécification. Grâce aux conseils de cet article, vous pouvez facilement mettre en œuvre la fonction de vérification des e-mails et améliorer l'expérience utilisateur et la sécurité de votre site Web. L'éditeur PHP Apple vous expliquera en détail la méthode de vérification des e-mails, vous permettant de maîtriser facilement les compétences.
Nous montrerons également une autre façon de vérifier les adresses e-mail dans FILTER_SANITIZE_EMAIL
和 FILTER_VALIDATE_EMAIL
过滤器名称 ID 以及 fiter_var()
php en utilisant la fonction . Cette méthode nettoie d’abord l’adresse e-mail, puis vérifie l’adresse e-mail.
Nous aborderons une autre façon de valider les e-mails en PHP à l'aide des Expressions régulières. Cette méthode utilise la fonction preg_match()
pour vérifier si l'e-mail est valide en fonction de l'expression régulière fournie.
filter_var()
函数和 FILTER_VALIDATE_EMAIL
E-mail de vérification en PHP
Nous pouvons utiliser le nom du filtre filter_var()
函数来过滤具有特定过滤器名称的变量。FILTER_VALIDATE_EMAIL
pour spécifier que l'e-mail doit être vérifié. La fonction prend l'adresse e-mail sous forme de String comme premier paramètre et l'ID de filtre spécifié ci-dessus comme deuxième paramètre. Nous pouvons donc vérifier si l'e-mail fourni est valide. Si la fonction réussit ou renvoie false, la fonction renvoie les données filtrées. On dit que l'e-mail est valide, mais que l'e-mail n'existe pas. L'identifiant du filtre valide l'e-mail en fonction de la syntaxe de la RFC 822. Nous pouvons testervérification des e-mails en utilisant des e-mails valides et invalides.
Par exemple, créez une fonction validateEmail()
,它接受一个参数 $email
。对 $email
变量使用 filter_var()
函数,并指定过滤器 ID FILTER_VALIDATE_EMAIL
作为第二个参数。对 filter_var()
函数应用 if-else
条件。在 if
块中,显示消息说电子邮件有效,在 else
条件下,显示该电子邮件无效。在函数外,调用该函数两次。在第一个函数调用中提供参数,peter.piper@iana.org
和 first.last@example.123
au deuxième appel.
Nous pouvons supposer que l'adresse e-mail fournie dans l'exemple est accessible depuis le formulaire en utilisant la variable $_POST
. La fonction dans l'exemple ci-dessous est appelée deux fois. Le premier appel transmet une adresse email valide, le second une adresse email invalide. La deuxième adresse e-mail n'est pas valide car elle contient un numéro du domaine de premier niveau. Les résultats sont évidents.
Exemple de code :
<code> <code class="language-php hljs" data-lang="php"><span style="display:flex;"><span><span style="color:#408080;font-style:italic">#php 7.x </span></span></span><span style="display:flex;"><span><span style="color:#666"><?</span>php </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">funct<strong class="keylink">io</strong>n</span> <span style="color:#00f">validateEmail</span>(<span style="color:#19177c">$email</span>) { </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">if</span>(filter_var(<span style="color:#19177c">$email</span>, FILTER_VALIDATE_EMAIL)) { </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">: A valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>; </span></span><span style="display:flex;"><span>} </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">else</span> { </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">: Not a valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>; </span></span><span style="display:flex;"><span>} </span></span><span style="display:flex;"><span>} </span></span><span style="display:flex;"><span>validateEmail(<span style="color:#ba2121">'peter.piper@iana.org'</span>); </span></span><span style="display:flex;"><span>validateEmail(<span style="color:#ba2121">'first.last@example.123'</span>); </span></span><span style="display:flex;"><span><span style="color:#bc7a00">?></span><span > </span></span></span></code></code>
Résultat :
<code> <code class="language-php hljs" data-lang="php"><span style="display:flex;"><span>phppeter<span style="color:#666">.</span>piper<span style="color:#666">@</span>iana<span style="color:#666">.</span>org<span style="color:#666">:</span> A valid email </span></span><span style="display:flex;"><span>first<span style="color:#666">.</span>last<span style="color:#666">@</span>example<span style="color:#666">.</span><span style="color:#666">123</span><span style="color:#666">:</span><span style="color:#008000;font-weight:bold">Not</span> a valid email </span></span></code></code>
FILTER_VALIDATE_EMAIL
、FILTER_SANITIZE_EMAIL
和 filter_var()
en PHP
Nous pouvons suivre la première approche en utilisant un identifiant de nom de filtre FILTER_SANITIZE_EMAIL
过滤器名称 id 从电子邮件地址中删除所有非法字符。过滤器名称 id 是 filter_var()
函数中的第二个参数,其中电子邮件地址是第一个参数。该函数返回经过消毒的电子邮件。我们可以再次使用该功能来检查消毒后电子邮件地址的有效性。为此,我们可以使用 FILTER_VALIDATE_EMAIL
supplémentaire dans la première approche.
Par exemple, créez une variable $email
并存储一个包含非法字符的电子邮件地址。将电子邮件 ram(.mugu)@exa//mple.org
作为字符串存储在变量中。对变量使用 filter_var()
函数,并使用 FILTER_SANITIZE_EMAIL
id 作为第二个参数。将函数存储在同一个 $email
变量中。然后,像第一种方法一样应用 if-else
语句。这一次,使用 FILTER_VALIDATE_EMAIL
email comme nom de filtre dans la fonction. De même, le message s'affiche.
L'exemple ci-dessous utilise une adresse e-mail contenant des caractères illégaux, filter_var()
函数过滤这些字符并清理所提供的电子邮件。示例中提供的电子邮件地址包含非法字符,例如 ()
和 //
. La fonction supprime d'abord ces caractères de l'e-mail puis valide l'e-mail.
Exemple de code :
<code> <code class="language-php hljs" data-lang="php"><span style="display:flex;"><span><span style="color:#408080;font-style:italic">#php 7.x </span></span></span><span style="display:flex;"><span><span style="color:#666"><?</span>php </span></span><span style="display:flex;"><span><span style="color:#19177c">$email</span> <span style="color:#666">=</span> <span style="color:#ba2121">"ram(.mugu)@exa//mple.org"</span>; </span></span><span style="display:flex;"><span><span style="color:#19177c">$email</span> <span style="color:#666">=</span> filter_var(<span style="color:#19177c">$email</span>, FILTER_SANITIZE_EMAIL); </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">if</span>(filter_var(<span style="color:#19177c">$email</span>, FILTER_VALIDATE_EMAIL)) { </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">: A valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>; </span></span><span style="display:flex;"><span>} </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">else</span>{ </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">:Not a valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>; </span></span><span style="display:flex;"><span>} </span></span><span style="display:flex;"><span><span style="color:#bc7a00">?></span><span > </span></span></span></code></code>
Résultat :
<code> <code class="language-php hljs" data-lang="php"><span style="display:flex;"><span>ram<span style="color:#666">.</span>mugu<span style="color:#666">@</span>example<span style="color:#666">.</span>org<span style="color:#666">:</span> A valid email </span></span></code></code>
preg_match()
函数根据正则表达式验证电子邮件
我们可以使用 preg_match()
函数来验证 PHP 中的电子邮件地址。此方法使用正则表达式作为电子邮件的验证规则。我们可以自己创建正则表达式并定义有效电子邮件的规则。preg_match()
函数接受两个参数,其中第一个是正则表达式,第二个是要检查的电子邮件。我们可以使用三元运算符和函数一起检查电子邮件的有效性。
例如,创建两个变量 $email_first
和 $email_secon
,并在这些变量中存储两个电子邮件地址。首先存储有效的电子邮件 firstlast11@gmail.com
,然后存储无效的电子邮件 firstlast@11gmail,com
。编写一个带有一个参数的函数 validateEmail()
。命名参数 $email
。在函数内部,在 $regex
变量中编写一个正则表达式,如示例代码所示。然后编写一个三元运算符,其中要检查的条件是 preg_match()
函数。将 $regex
作为第一个参数,将 $email
作为第二个参数。当条件为真时打印电子邮件有效的消息,当条件为假时打印电子邮件无效的消息。回显整个三元表达式。在函数外,调用 validateEmail()
函数两次。在第一个函数调用中使用 $email_first
变量,在第二个函数调用中使用 $email_second
变量。
在下面的示例中,我们编写了一个正则表达式,用于创建验证电子邮件的规则。有效的电子邮件包含收件人姓名、@
符号、域和顶级域。上面创建的正则表达式接受收件人姓名作为字母数字值。字母表由大写字母和小写字母组成。它也接受一个句点。电子邮件必须有 @
符号。该域仅包含字母。然后电子邮件应该有一个句点。顶级域应该只由字母组成,并且长度应该是两个或三个。正则表达式是基于此规则创建的。第一封电子邮件是有效的,因为它满足所有规则,但第二封电子邮件无效。无效,因为域名中有数字,顶级域名前没有句号。
示例代码:
<code> <code class="language-php hljs" data-lang="php"><span style="display:flex;"><span><span style="color:#408080;font-style:italic"># php 7.x </span></span></span><span style="display:flex;"><span><span style="color:#666"><?</span>php </span></span><span style="display:flex;"><span><span style="color:#19177c">$email_first</span> <span style="color:#666">=</span> <span style="color:#ba2121">'firstlast11@gmail.com'</span>; </span></span><span style="display:flex;"><span><span style="color:#19177c">$email_second</span> <span style="color:#666">=</span><span style="color:#ba2121">'firstlast@11gmail,com'</span>; </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">function</span> <span style="color:#00f">validateEmail</span>(<span style="color:#19177c">$email</span>) { </span></span><span style="display:flex;"><span><span style="color:#19177c">$regex</span> <span style="color:#666">=</span> <span style="color:#ba2121">"/^([a-zA-Z0-9\.]+@+[a-zA-Z]+(\.)+[a-zA-Z]{2,3})$/"</span>; </span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> preg_match(<span style="color:#19177c">$regex</span>, <span style="color:#19177c">$email</span>) <span style="color:#666">?</span> <span style="color:#ba2121">"The email is valid"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span> <span style="color:#666">:</span><span style="color:#ba2121">"The email is not valid"</span>; </span></span><span style="display:flex;"><span>} </span></span><span style="display:flex;"><span>validateEmail(<span style="color:#19177c">$email_first</span>); </span></span><span style="display:flex;"><span>validateEmail(<span style="color:#19177c">$email_second</span>); </span></span><span style="display:flex;"><span><span style="color:#bc7a00">?></span><span > </span></span></span></code></code>
输出:
<code> <code class="language-text hljs" data-lang="text"><span style="display:flex;"><span>The email is valid </span></span><span style="display:flex;"><span>The email is not valid </span></span></code></code>
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!