快捷搜索:   nginx

PHP验证邮箱有效性验证邮箱后缀域名是否真实存在的方法(过滤+DNS验证)

PHP检验邮箱有效性的方法其实可以很简单,用到内部函数就行,连正则都可以不用写。

首先是filter_var函数

filter_var是PHP内置的一个变量过滤的方法, 提供了很多实用的过滤器, 可以用来校验整数、浮点数、邮箱、URL、MAC地址等。

filter_var如果返回false, 说明变量无法通过过滤器, 也就是不合法了。

$email = "bnxb.com@163.com";
 
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
 
$email = "asb";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
$email = "1@a.com";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));

输出:

string(21) "bnxb.com@163.com"
bool(false)
string(7) 1@a.com

对于asb这种非法邮箱格式返回了false, 但对于1@a.com这种我们明显可以看出是有问题的邮箱却通过了,还是存在小问题。

不过即使你是写正则判断,正则也是会认为1@a.com是一个合法的邮箱,那还有什么办法解决这个小问题呢?


那就用checkdnsrr函数

checkdnsrr其实是用来查询指定的主机的DNS记录的,我们可以借用它来验证邮箱是否存在。

对于1@a.com肯定是MX记录不存在的。

$email = "bnxb.com@163.com";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
  $email = "1@a.com";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));

输出:

  bool(true)
  bool(false)

可以看到, 很完美,但缺点就是太慢了,毕竟是要请求一次DNS记录。 所以不适合对大量的邮箱采用这种做法去校验。


filter_var+checkdnsrr结合方案

我们可以结合filter_var 和checkdnsrr做校验, 对于绝大多数的非法邮箱在filter_var的时候就被排除了, 剩下的再用checkdnsrr进一步判断。

$email_arr = array("bnxb.com@163.com", "1@a.com");
  foreach($email_arr as $email) {
    if (filter_var($email) === false) {
      echo "invalid email: $email \n";
      continue;
    }
 
    if(checkdnsrr(array_pop(explode("@",$email)),"MX") === false) {
      echo "invalid email: $email \n";
      continue;
    }
  }

   输出:

invalid email: 1@a.com

但要注意的是, 由于只是检查MX记录, 所以只能判断@163.com确实是有提供邮箱, 但不能说明bnxb.com这个用户是存在的。

想要更精确的判断邮箱存在, 那只能连接到smtp服务器去验证了。


下面附上函数说明:

filter_var函数

语法
filter_var(variable, filter, options)
variable 必需。规定要过滤的变量。
filter 可选。规定要使用的过滤器的 ID。
options 规定包含标志/选项的数组。检查每个过滤器可能的标志和选项。

PHP Filters

Example #1 A filter_var() example

<?php

var_dump(filter_var('bob@example.com', FILTER_VALIDATE_EMAIL));

var_dump(filter_var('http://example.com', FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));

?>

以上例程会输出:

string(15) "bob@example.com"
bool(false)


顶(0)
踩(0)

您可能还会对下面的文章感兴趣:

最新评论