当前位置:首页 > PHP教程 > 正则表达式 > 列表

PHP验证邮箱与邮箱有效性验证

发布:smiling 来源: PHP粉丝网  添加日期:2014-01-25 23:00:53 浏览: 评论:0 

下面我来总结了在php邮箱验证的正则表达式以及还可以checkdnsrr函数来验证你输入的邮箱是否是有效的哦,这样可以更好的过滤到无效邮箱地址哦。

域名由各国文字的特定字符集、英文字母、数字及“-”(即连字符或减号)任意组合而成, 但开头及结尾均不能含有“-”,“-”不能连续出现 。 域名中字母不分大小写。域名最长可达60个字节(包括后缀.com、.net、.org等)。

/^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[.][a-z]{2,3}([.][a-z]{2})?$/i;/内容/i 构成一个不区分大小写的正则表达式

代码如下:

  1. $email = "tanklo_--vehy@yahoo.com.cn"
  2.     function check_email($email) { 
  3.        $pattern_test = "/([a-z0-9]*[-_.]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[.][a-z]{2,3}([.][a-z]{2})?/i"
  4.        return  preg_match($pattern_test,$email); 
  5.     } 
  6. echo check_email($email); 

上面的只能简单的验证邮件格式,下面一个更具体验证方法,PHP如何验证,代码如下:

  1. <? 
  2. //PHP验证邮箱格式的函数 
  3. function valid_email($email) { 
  4. // First, we check that there's one @ symbol, and that the lengths are right 
  5. if (!ereg("^[^@]{1,64}@[^@]{1,255}$"$email)) { 
  6. // Email invalid because wrong number of characters in one section, or wrong number of @ symbols. 
  7. return false; 
  8. // Split it into sections to make life easier 
  9. $email_array = explode("@"$email); 
  10. $local_array = explode("."$email_array[0]); 
  11. for ($i = 0; $i < sizeof($local_array); $i++) { 
  12. if (!ereg("^(([A-Za-z0-9!#$%&#038;'*+/=?^_`{|}~-][A-Za-z0-9!#$%&#038;'*+/=?^_`{|}~.-]{0,63})|("[^(\|")]{0,62}"))$", $local_array[$i])) { 
  13. return false; 
  14. if (!ereg("^[?[0-9.]+]?$"$email_array[1])) { // Check if domain is IP. If not, it should be valid domain name 
  15. $domain_array = explode("."$email_array[1]); 
  16. if (sizeof($domain_array) < 2) { 
  17. return false; // Not enough parts to domain 
  18. for ($i = 0; $i < sizeof($domain_array); $i++) { 
  19. if (!ereg("^(([A-Za-z0-9][A-Za-z0-9-]{0,61}[A-Za-z0-9])|([A-Za-z0-9]+))$"$domain_array[$i])) { 
  20. return false; 
  21. return true; 
  22.  
  23. //应用示例 
  24. if(!valid_email($myeml)){ 
  25. echo"<script>alert('Please enter a valid e-mail address');location.href='javascript:history.back()'</script>"
  26. break
  27. ?> 

无意中就发现checkdnsrr函数那里就有了更精妙的例子,分享给大家,代码如下:

  1. <?php 
  2. function validate_email($email){ 
  3. $exp = "^[a-z'0-9]+([._-][a-z'0-9]+)*@([a-z0-9]+([._-][a-z0-9]+))+$"
  4. if(eregi($exp,$email)){ //先用正则表达式验证email格式的有效性 
  5. if(checkdnsrr(array_pop(explode("@",$email)),"MX")){//再用checkdnsrr验证email的域名部分的有效性 
  6. return true; 
  7. }else
  8. return false; 
  9. }else
  10. return false; 
  11. ?> 

Tags: 验证 邮箱 有效性验证

分享到: