在 PHP 中验证电子邮件
-
在 PHP 中使用
filter_var()
函数和FILTER_VALIDATE_EMAIL
验证电子邮件 -
在 PHP 中使用
FILTER_VALIDATE_EMAIL
、FILTER_SANITIZE_EMAIL
和filter_var()
函数验证电子邮件 -
使用
preg_match()
函数根据正则表达式验证电子邮件
我们将介绍一种使用 filter_var()
函数和 FILTER_VALIDATE_EMAIL
过滤器名称 ID 在 PHP 中验证电子邮件地址的方法。filter_var()
函数将电子邮件作为第一个参数和过滤器名称 FILTER_VALIDATE_EMAIL
以根据 RFC 822 中的语法验证电子邮件。此方法检查有效的电子邮件格式而不是有效的电子邮件。
我们还将演示另一种使用 FILTER_SANITIZE_EMAIL
和 FILTER_VALIDATE_EMAIL
过滤器名称 ID 以及 fiter_var()
函数在 PHP 中验证电子邮件地址的方法。此方法首先清理电子邮件地址,然后验证电子邮件地址。
我们将介绍另一种使用正则表达式在 PHP 中验证电子邮件的方法。此方法使用 preg_match()
函数根据提供的正则表达式检查电子邮件是否有效。
在 PHP 中使用 filter_var()
函数和 FILTER_VALIDATE_EMAIL
验证电子邮件
我们可以使用 filter_var()
函数来过滤具有特定过滤器名称的变量。FILTER_VALIDATE_EMAIL
过滤器名称指定电子邮件需要验证。该函数将电子邮件地址作为字符串作为第一个参数,将上面指定的过滤器 ID 作为第二个参数。因此,我们可以检查提供的电子邮件是否有效。如果函数成功或返回 false,则函数返回过滤后的数据。电子邮件被称为有效,而不是电子邮件存在的意义。过滤器 id 根据 RFC 822 中的语法验证电子邮件。我们可以使用有效和无效的电子邮件来测试电子邮件的验证。
例如,创建一个函数 validateEmail()
,它接受一个参数 $email
。对 $email
变量使用 filter_var()
函数,并指定过滤器 ID FILTER_VALIDATE_EMAIL
作为第二个参数。对 filter_var()
函数应用 if-else
条件。在 if
块中,显示消息说电子邮件有效,在 else
条件下,显示该电子邮件无效。在函数外,调用该函数两次。在第一个函数调用中提供参数,peter.piper@iana.org
和 first.last@example.123
在第二次通话中。
我们可以假设示例中提供的电子邮件地址是使用 $_POST
变量从表单访问的。下面示例中的函数被调用两次。第一个调用传递一个有效的电子邮件地址,第二个地址传递一个无效的电子邮件。第二个电子邮件地址无效,因为它包含顶级域中的数字。结果是显而易见的。
示例代码:
#php 7.x
<?php
function validateEmail($email) {
if(filter_var($email, FILTER_VALIDATE_EMAIL)) {
echo "{$email}: A valid email"."<br>";
}
else {
echo "{$email}: Not a valid email"."<br>";
}
}
validateEmail('peter.piper@iana.org');
validateEmail('first.last@example.123');
?>
输出:
phppeter.piper@iana.org: A valid email
first.last@example.123:Not a valid email
在 PHP 中使用 FILTER_VALIDATE_EMAIL
、FILTER_SANITIZE_EMAIL
和 filter_var()
函数验证电子邮件
我们可以在第一种方法中使用附加的 FILTER_SANITIZE_EMAIL
过滤器名称 id 从电子邮件地址中删除所有非法字符。过滤器名称 id 是 filter_var()
函数中的第二个参数,其中电子邮件地址是第一个参数。该函数返回经过消毒的电子邮件。我们可以再次使用该功能来检查消毒后电子邮件地址的有效性。为此,我们可以使用 FILTER_VALIDATE_EMAIL
过滤器名称 id 来遵循第一种方法。
例如,创建一个变量 $email
并存储一个包含非法字符的电子邮件地址。将电子邮件 ram(.mugu)@exa//mple.org
作为字符串存储在变量中。对变量使用 filter_var()
函数,并使用 FILTER_SANITIZE_EMAIL
id 作为第二个参数。将函数存储在同一个 $email
变量中。然后,像第一种方法一样应用 if-else
语句。这一次,使用 FILTER_VALIDATE_EMAIL
电子邮件作为函数中的过滤器名称。同样,显示消息。
在下面的示例中采用了带有非法字符的电子邮件地址,filter_var()
函数过滤这些字符并清理所提供的电子邮件。示例中提供的电子邮件地址包含非法字符,例如 ()
和 //
。该函数首先从电子邮件中删除这些字符,然后验证电子邮件。
示例代码:
#php 7.x
<?php
$email = "ram(.mugu)@exa//mple.org";
$email = filter_var($email, FILTER_SANITIZE_EMAIL);
if(filter_var($email, FILTER_VALIDATE_EMAIL)) {
echo "{$email}: A valid email"."<br>";
}
else{
echo "{$email}:Not a valid email"."<br>";
}
?>
输出:
ram.mugu@example.org: A valid email
使用 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
变量。
在下面的示例中,我们编写了一个正则表达式,用于创建验证电子邮件的规则。有效的电子邮件包含收件人姓名、@
符号、域和顶级域。上面创建的正则表达式接受收件人姓名作为字母数字值。字母表由大写字母和小写字母组成。它也接受一个句点。电子邮件必须有 @
符号。该域仅包含字母。然后电子邮件应该有一个句点。顶级域应该只由字母组成,并且长度应该是两个或三个。正则表达式是基于此规则创建的。第一封电子邮件是有效的,因为它满足所有规则,但第二封电子邮件无效。无效,因为域名中有数字,顶级域名前没有句号。
示例代码:
# php 7.x
<?php
$email_first = 'firstlast11@gmail.com';
$email_second ='firstlast@11gmail,com';
function validateEmail($email) {
$regex = "/^([a-zA-Z0-9\.]+@+[a-zA-Z]+(\.)+[a-zA-Z]{2,3})$/";
echo preg_match($regex, $email) ? "The email is valid"."<br>" :"The email is not valid";
}
validateEmail($email_first);
validateEmail($email_second);
?>
输出:
The email is valid
The email is not valid
Subodh is a proactive software engineer, specialized in fintech industry and a writer who loves to express his software development learnings and set of skills through blogs and articles.
LinkedIn