php 检查email电子邮件函数

电子邮箱验证是我们开发应用中常用的,特别在表单提交时会有验证了,下面我分析了一些邮箱地址的规则从而整理了一些常用了电子邮箱验证语句与各位分享.

以前写的一个PHP表单电子邮件发送程序,其中采用如下方法来验证电子邮件地址格式是否正确,代码如下:

eregi("^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9_-]+.[a-z0-9_-]+.*", $email)

后来发现类似于将误写为的电子邮件地址也能通过验证,例如user@126,com,经过检查,发现它实际上只验证了用户名部分,所以又在网上找到一个教程,其中给出的例子如下:

eregi('^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$',$email)

经过检查,发现电子邮件地址user@126,com仍然能够通过它的验证,找到了一个示例:

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

这个看起来更加合理一些,因为它对后缀名称进行了验证,尽管现在出现了4个字符以上的顶级域名,但是只需要稍加修改即可,不过电子邮件地址user@xxx,com 仍然能够通过验证,仔细检查后发现是因为没有对,进行转义导致,于是对它稍做修改:

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

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

例1代码如下:

  1. <?php
  2. function is_valid_email($email, $test_mx = false)
  3. {
  4. if(eregi("^([_a-z0-9-]+)(.[_a-z0-9-]+)*@([a-z0-9-]+)(.[a-z0-9-]+)*(.[a-z]{2,4})$", $email))
  5. if($test_mx)
  6. {
  7. list($username, $domain) = split("@", $email);
  8. return getmxrr($domain, $mxrecords);
  9. }
  10. else
  11. return true;
  12. else
  13. return false;
  14. }
  15. ?>

例2代码如下:

  1. function is_valid_email_address($email){
  2. $qtext = '[^//x0d//x22//x5c//x80-//xff]';
  3. $dtext = '[^//x0d//x5b-//x5d//x80-//xff]';
  4. $atom = '[^//x00-//x20//x22//x28//x29//x2c//x2e//x3a-//x3c'.
  5. '//x3e//x40//x5b-//x5d//x7f-//xff]+';
  6. $quoted_pair = '//x5c[//x00-//x7f]';
  7. $domain_literal = "//x5b($dtext|$quoted_pair)*//x5d";
  8. $quoted_string = "//x22($qtext|$quoted_pair)*//x22";
  9. $domain_ref = $atom;
  10. $sub_domain = "($domain_ref|$domain_literal)";
  11. $word = "($atom|$quoted_string)";
  12. $domain = "$sub_domain(//x2e$sub_domain)*";
  13. $local_part = "$word(//x2e$word)*";
  14. $addr_spec = "$local_part//x40$domain";
  15. return preg_match("!^$addr_spec$!", $email) ? 1 : 0;
  16. }