在 PHP 中验证电子邮件

在php中验证电子邮件是网站开发中常见的需求之一。有效的电子邮件验证可以提高用户输入准确性,防止恶意注册和信息泄露。本文将介绍如何使用php编写简单而有效的电子邮件验证代码,以确保用户输入的电子邮件格式符合规范。通过本文的指导,您可以轻松实现电子邮件验证功能,提升网站的用户体验和安全性。php小编苹果将为您详细解读验证电子邮件的方法,让您轻松掌握技巧。

我们还将演示另一种使用 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<?phpfunction validateEmail($email) {if(filter_var($email, FILTER_VALIDATE_EMAIL)) {echo "{$email}: A valid email"."
"
;
}else {echo "{$email}: Not a valid email"."
"
;
}}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"."
"
;
}else{echo "{$email}:Not a valid email"."
"
;
}?>

登录后复制

输出:

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"."
"
:"The email is not valid";
}validateEmail($email_first);validateEmail($email_second);?>

登录后复制

输出:

The email is valid The email is not valid

登录后复制

以上就是在 PHP 中验证电子邮件的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1630292.html

(0)
上一篇 2025年2月19日 02:40:17
下一篇 2025年2月19日 02:40:31

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • PHP开发商城中的商品评论回复功能实现方法

    php开发商城中的商品评论回复功能实现方法 随着电子商务的迅猛发展,越来越多的人选择在网上购物。在购物过程中,消费者往往需要通过商品评论来了解其他消费者的评价,从而做出自己的购买决策。因此,在商城系统中添加商品评论回复功能成为了必不可少的一…

    编程技术 2025年2月23日
    100
  • PHP数据加密解密处理方法简介

    php作为一种流行的服务器端脚本语言,提供了丰富的加密和解密函数库,用于处理敏感数据的保护和恢复。本文将介绍php中常用的数据加密和解密方法,以及如何使用它们来保护数据的安全性。 首先,我们需要了解加密和解密的基本概念。加密是指将明文转换成…

    编程技术 2025年2月23日
    100
  • 网站安全策略:PHP防止IDOR攻击

    近年来,随着互联网的迅猛发展和大规模数字化转型,网站安全问题日益突出。其中一种常见的攻击方式是idor(insecure direct object reference)攻击。idor攻击指的是攻击者通过直接访问应用程序内的对象引用来绕过安…

    编程技术 2025年2月23日
    100
  • PHP实现在线支付和订单处理的方法?

    如何在php实现在线支付和订单处理? 随着互联网的迅猛发展,越来越多的商家开始将业务转移到线上。在线支付和订单处理成为了商家们面临的重要问题。在这个过程中,PHP作为一种广泛应用的编程语言,被广泛应用于在线支付和订单处理的开发中。本文将讨论…

    编程技术 2025年2月23日
    100
  • PHP反射和动态扩展的使用方法?

    如何使用php的反射和动态扩展功能? 随着Web应用程序的不断发展,开发人员对于动态扩展和灵活性的需求也越来越高。PHP作为一种流行的服务器端脚本语言,提供了反射和动态扩展功能,使得开发人员可以在运行时修改和获取对象的信息,以及动态添加和卸…

    编程技术 2025年2月23日
    100
  • HMAC技术保护PHP数据完整性

    hmac (hash-based message authentication code) 是一种在计算机通信中用于保护数据完整性的技术。它结合了散列函数和密钥,可以用于验证数据在传输过程中是否被篡改。 在网络通信中,数据的安全性是一项非常…

    编程技术 2025年2月23日
    100
  • PHP密码重置与找回功能实现方法?

    php是一种广泛应用于web开发的脚本语言,具有强大的功能和灵活性。其中,密码重置和找回功能是目前很多网站都需要实现的常见功能之一。本文将介绍php如何进行密码重置和找回功能的实现。 一、密码重置功能 用户请求重置密码当用户忘记密码或需要重…

    编程技术 2025年2月23日
    100
  • PHP URL重写和路由解析的方法?

    php作为一种服务器端脚本语言,被广泛应用于web开发中。在开发过程中,我们经常会遇到需要进行url重写和路由解析的情况。本文将介绍php中的url重写和路由解析的基本原理和实现方法。 一、URL重写的基本原理 URL重写是一种将动态的UR…

    编程技术 2025年2月23日
    100
  • 二手回收网站利用PHP开发的多种付款方式选择

    二手回收网站利用php开发的多种付款方式选择 随着社会经济的发展和消费水平的提高,二手回收市场逐渐兴起。为了方便用户进行交易,二手回收网站需要提供多种付款方式选择。本文将介绍如何利用PHP开发一个二手回收网站,并实现多种付款方式的选择。 首…

    编程技术 2025年2月23日
    100
  • PHP 实现知识问答网站中的问题讨论和评价功能。

    php 实现知识问答网站中的问题讨论和评价功能 随着信息时代的到来,知识问答网站越来越受到人们的关注和青睐。这些网站不仅为用户提供了一个互相交流和共享知识的平台,还能让用户通过讨论和评价功能更好地获取有用的信息。本文将介绍如何使用PHP实现…

    编程技术 2025年2月23日
    100

发表回复

登录后才能评论