黑帽联盟

 找回密码
 会员注册
查看: 1835|回复: 0
打印 上一主题 下一主题

[php] PHP自带方法验证邮箱是否存在

[复制链接]
yun 黑帽联盟官方人员 

920

主题

37

听众

1364

积分

超级版主

Rank: 8Rank: 8

  • TA的每日心情
    奋斗
    2019-10-18 11:20
  • 签到天数: 678 天

    [LV.9]以坛为家II

    PHP校验邮箱地址的方法很多, 比较常用的就是自己写正则了, 不过正则多麻烦, 我PHP自带了方法做校验。

    filter_var

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

    filter_var如果返回false, 说明变量无法通过过滤器, 也就是不合法了。
    $email = "cnblackhat@qq.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) "cnblackhat@qq.com"
    bool(false)
    string(7) 1@a.com
    对于asb这种非法邮箱格式返回了false, 但对于1@a.com则通过了,还是略有瑕疵啊。

    不过一般的正则也通过会认为1@a.com是一个合法的邮箱, 那有啥办法可以更精准的验证呢?

    checkdnsrr

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

    对于1@a.com肯定是MX记录不存在的。
    $email = "lastchiliarch@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)
    可以看到, 很完美, 唯一的缺点就是太慢了, 毕竟是要做一次网络请求。 所以不适合同步对大量的邮箱采用这种做法去校验。

    filter_var+checkdnsrr

    我们可以接合filter_var 和checkdnsrr做校验, 对于绝大多数的非法邮箱肯定会在filter_var的时候就挂掉了, 剩下的再用

    checkdnsrr进一步判断。
    $email_arr = array("cnblackhat@qq.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记录, 所以只能判断qq.com是存在的, 但不能说明cnblackhat这个用户是存在的。

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

    介绍了邮箱验证,PHP自带方法如何验证邮箱、URL、IP是否合法,下面为大家介绍:

    主要还是使用的是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)

    以上就是本文的全部内容,希望对大家进行php邮箱验证有所帮助。

    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部