0

由于erigi()在 PHP 5 中已弃用并且我需要验证电子邮件 ID,应该使用哪个函数?我需要电子邮件验证的格式,例如:

<?php
function checkEmail($email) 
{
   if(eregi("^[a-zA-Z0-9_]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-\.]+$]", $email)) 
   {
      return FALSE;
   }

   list($Username, $Domain) = split("@",$email);

   if(getmxrr($Domain, $MXHost)) 
   {
      return TRUE;
   }
   else 
   {
      if(fsockopen($Domain, 25, $errno, $errstr, 30)) 
      {
         return TRUE; 
      }
      else 
      {
         return FALSE; 
      }
   }
}
?>
4

3 回答 3

2

对于 php 5.2: http: //php.net/manual/en/function.filter-var.php

$result = filter_var($email , FILTER_VALIDATE_EMAIL);

http://pl.php.net/manual/en/function.preg-match.php获取任何正则表达式。

于 2010-09-19T10:53:09.303 回答
2

请改用filter_varPHP 函数:

if (filter_var($email, FILTER_VALIDATE_EMAIL)) {

}

或者,更好的是,使用符合 RFC 的电子邮件地址验证器。因为没有多少正则表达式会包含所有可能的有效电子邮件。

于 2010-09-19T10:53:20.333 回答
0

带有过滤器扩展的示例。

<?php
function is_valid_email($email)
{
    return filter_var($email, FILTER_VALIDATE_EMAIL) !== false;
}

var_dump(is_valid_email('test@example.com'));
var_dump(is_valid_email('foobar'));
var_dump(is_valid_email('test+foo@example.com.com'));

[~]> php x.php 
bool(true)
bool(false)
bool(true)

然后,您可以将其与您已经拥有的进一步验证结合起来。

于 2010-09-19T10:57:31.800 回答