PHP email validation
本问题已经有最佳答案,请猛点这里访问。
对于php来说,使用preg(而不是ereg)进行电子邮件验证的最佳方法是什么,因为它被弃用/删除了。
我不需要检查网站是否存在(这不像是最大的安全性)。
我发现了很多方法,但它们(显然)不是很好的实践。
我建议您使用
1 2 3 |
还可以直接使用其正则表达式:
1 | "/^(?!(?:(?:\\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" |
但是在这种情况下,如果在正则表达式中发现了一个bug,那么您将不得不更新程序,而不仅仅是更新php。
除非你想使用一个非常长的正则表达式,否则你会遇到没有覆盖的有效电子邮件地址(比如unicode)。同样,假电子邮件地址也会被视为有效的,那么,如果你只需写[email protected]就可以摆脱它,那么验证的意义是什么呢?
验证电子邮件地址的最佳方法是发送一封确认电子邮件,其中包含一个要单击的链接。这只在电子邮件地址有效时有效:简单,不需要使用regex。
1 2 3 4 5 6 7 8 | function check_email($check) { $expression ="/^[a-zA-Z0-9._-]+@[a-zA-Z0-9._-]+\.([a-zA-Z]{2,4})$/"; if (preg_match($expression, $check)) { return true; } else { return false; } } |
在if()条件中调用它,如下示例:
1 2 3 4 | if(!check_email($_REQUEST['ContactEmail'])){ $register_error ="Enter the correct email address!<br />"; $reg_error=1; } |