Possible Duplicate:
07000Duplicate: 07000
我知道这是一个常见的问题,但在验证电子邮件地址时,我仍然无法找到一个很好的正则表达式.
我没有时间去阅读规范并自己编写.你以前用过什么,它运作得好吗?我并不关心100%匹配规格,但越接近越好.
这是我使用的功能.它只是通过正则表达式运行电子邮件地址,但到目前为止它是我找到的最完整的解决方案:
function validEmail($email,$skipDNS = false) { $isValid = true; $atIndex = strrpos($email,"@"); if (is_bool($atIndex) && !$atIndex) { $isValid = false; } else { $domain = substr($email,$atIndex+1); $local = substr($email,$atIndex); $localLen = strlen($local); $domainLen = strlen($domain); if ($localLen < 1 || $localLen > 64) { // local part length exceeded $isValid = false; } else if ($domainLen < 1 || $domainLen > 255) { // domain part length exceeded $isValid = false; } else if ($local[0] == '.' || $local[$localLen-1] == '.') { // local part starts or ends with '.' $isValid = false; } else if (preg_match('/\\.\\./',$local)) { // local part has two consecutive dots $isValid = false; } else if (!preg_match('/^[A-Za-z0-9\\-\\.]+$/',$domain)) { // character not valid in domain part $isValid = false; } else if (preg_match('/\\.\\./',$domain)) { // domain part has two consecutive dots $isValid = false; } else if (!preg_match('/^(\\\\.|[A-Za-z0-9!#%&`_=\\/$\'*+?^{}|~.-])+$/',str_replace("\\\\","",$local))) { // character not valid in local part unless // local part is quoted if (!preg_match('/^"(\\\\"|[^"])+"$/',$local))) { $isValid = false; } } if(!$skipDNS) { if ($isValid && !(checkdnsrr($domain,"MX") || checkdnsrr($domain,"A"))) { // domain not found in DNS $isValid = false; } } } return $isValid; }
该函数有一个可选的$skipDNS参数,如果您不想验证hos的MX记录,可以将其设置为TRUE.否则,该函数将尝试验证提供的电子邮件地址是否实际映射到真实的电子邮件服务器.
值得注意的是,大多数RegEx电子邮件验证技术将验证大多数电子邮件地址,但它们很可能会允许一些精心设计的无效地址,或者最糟糕的……在一些更加模糊但有效的电子邮件地址上失败.有关详细信息,您可能需要查看Internet Message Formats RFC,其中描述了允许的电子邮件地址格式.