PHP用正则表达式验证电子邮件格式

在网上查了下电子邮件格式的验证,做下总结。

eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,3}$",$str)

这个看起来更加合理一些,因为它对后缀名称进行了验证,尽管现在出现了4个字符以上的顶级域名,但是只需要稍加修改即可。不过电子邮件地址user@xxx,com仍然能够通过验证,仔细检查后发现是因为没有对.进行转义导致。于是对它稍做修改:
eregi("^[_\.0-9a-[a-z0-9z-]+@([0-9a-z][0-9a-z-]+\.)+[a-z]{2,4}$)

虽然它对用户名的检查要更加宽松一些,但是现在使用它的效果似乎不错。

 

 

<?php
function check_email( $email ) {
    if ( ereg ("^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+$”, $email )) {
        return true;
    } else {
        return false;
    }
}
?>
这个是没有判断固定范围的后缀。
还是不太清楚,怎么样的格式才是正确的电子邮箱格式。

 

 http://blog.csdn.net/youaregoo/article/details/7898331
这里找到一个比较好的
‘/^[a-z0-9]([a-z0-9]*[-_\.]?[a-z0-9]+)*@[a-z0-9]*([-_\.]?[a-z0-9]+)+[\.][a-z0-9]{2,3}([\.][a-z0-9]{2})?$/i’
 

你可能感兴趣的:(PHP,正则表达式,user,email)