php验证电子邮件,如何在PHP中验证电子邮件地址

检查电子邮件地址是否格式良好的最简单和最安全的方法是使用filter_var()职能:if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {

// invalid emailaddress}

此外,您还可以检查域是否定义了MX记录:if (!checkdnsrr($domain, 'MX')) {

// domain is not valid}

但这仍然不能保证邮件的存在。只有通过发送确认邮件才能发现这一点。

现在你有了你的简单答案,如果你想学习或者其他的话,可以自由地阅读关于电子邮件地址验证的内容,只需使用快速的答案,然后继续前进。没什么不好的感觉。

尝试使用regex验证电子邮件地址是一项“不可能”的任务。我甚至可以说你所做的审判是无用的。有三个RFC关于电子邮件地址和写一个regex来捕捉错误的电子邮件,同时没有假阳性是没有凡人可以做的事情。检查这份清单对于PHP所使用的正则表达式的测试(包括失败和成功)filter_var()功能。

即使是内置的PHP函数、电子邮件客户端或服务器也不正确。在大多数情况下filter_var是最好的选择。

如果您想知道PHP(当前)使用哪种regex模式来验证电子邮件地址,请参见PHP源程序.

如果您想了解更多关于电子邮件地址的信息,我建议您开始阅读这些规范,但我必须警告您,这并不是一件容易的事情:

请注意filter_var()如前所述,仅在PHP5.2时才可用。如果您希望它与早期版本的PHP一起使用,您可以使用PHP中使用的正则表达式:

$pattern = '/^(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){255,})(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){65,}@)(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22))(?:\\.(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22)))*@(?:(?:(?!.*[^.]{64,})(?:(?:(?:xn--)?[a-z0-9]+(?:-+[a-z0-9]+)*\\.){1,126}){1,}(?:(?:[a-z][a-z0-9]*)|(?:(?:xn--)[a-z0-9]+))(?:-+[a-z0-9]+)*)|(?:\\[(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){7})|(?:(?!(?:.*[a-f0-9][:\\]]){7,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?)))|(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){5}:)|(?:(?!(?:.*[a-f0-9]:){5,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3}:)?)))?(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))(?:\\.(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))){3}))\\]))$/iD';

$emailaddress = 'test@gmail.com';

if (preg_match($pattern, $emailaddress) === 1) {

// emailaddress is valid

}

关于上面使用的regex模式的说明(来自PHP源代码)。它看起来好像有一些版权迈克尔·拉什顿..如前所述:“请随意使用和重新分发此代码。但请保留此版权通知。”

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值