PHP电子邮件验证
PHP电子邮件验证
这个问题已经有了答案:
对于 PHP 来说,使用 preg 的最佳电子邮件验证是什么,不要使用 ereg,因为它已经弃用/移除了。
我不需要检查网站是否存在(这不像最大安全性那样)。
我已经找到了许多 ereg 的方法,但它们(显然)不是好的做法。
admin 更改状态以发布 2023年5月23日
除非您想使用非常非常长的正则表达式,否则您将遇到未覆盖的有效电子邮件地址(考虑Unicode字符)。另外,假电子邮件地址也会通过验证,那么如果您可以简单地编写test@test.com并且可以取得成功,那么进行验证的意义是什么呢?
验证电子邮件地址的最佳方法是发送一封包含链接的确认电子邮件进行单击。这仅在电子邮件地址有效时才起作用:简单易行,无需使用正则表达式。
我建议您使用FILTER_VALIDATE_EMAIL
过滤器:
if (filter_var($email, FILTER_VALIDATE_EMAIL)) { //valid }
您还可以直接使用其正则表达式:
"/^(?!(?:(?:\\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"
但在这种情况下,如果正则表达式中发现了漏洞,您必须更新您的程序而不是仅更新PHP。