在网上查了下电子邮件格式的验证,做下总结。
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.youkuaiyun.com/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’
这里找到一个比较好的
‘/^[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’