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

下面我来总结了在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. }
  9. // Split it into sections to make life easier
  10. $email_array = explode("@", $email);
  11. $local_array = explode(".", $email_array[0]);
  12. for ($i = 0; $i < sizeof($local_array); $i++) {
  13. if (!ereg("^(([A-Za-z0-9!#$%&#038;'*+/=?^_`{|}~-][A-Za-z0-9!#$%&#038;'*+/=?^_`{|}~.-]{0,63})|("[^(\|")]{0,62}"))$", $local_array[$i])) {
  14. return false;
  15. }
  16. }
  17. if (!ereg("^[?[0-9.]+]?$", $email_array[1])) { // Check if domain is IP. If not, it should be valid domain name
  18. $domain_array = explode(".", $email_array[1]);
  19. if (sizeof($domain_array) < 2) {
  20. return false; // Not enough parts to domain
  21. }
  22. for ($i = 0; $i < sizeof($domain_array); $i++) {
  23. if (!ereg("^(([A-Za-z0-9][A-Za-z0-9-]{0,61}[A-Za-z0-9])|([A-Za-z0-9]+))$", $domain_array[$i])) {
  24. return false;
  25. }
  26. }
  27. }
  28. return true;
  29. }
  30. //应用示例
  31. if(!valid_email($myeml)){
  32. echo"<script>alert('Please enter a valid e-mail address');location.href='javascript:history.back()'</script>";
  33. break;
  34. }
  35. ?>

无意中就发现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. }
  10. }else{
  11. return false;
  12. }
  13. }
  14. ?>