0

我现在更喜欢使用 SMTP 发送批量电子邮件。在发送邮件之前,我需要检查这些邮件 ID 是否有效。我有一个代码来检查它,我在下面添加了它。它来自 Github。我只需要通过使用此 DNS 端口检查与您确认所有这些,当检查大量无效邮件时,它是否会使我们的服务器陷入黑名单等问题?

<?php
function verifyEmail($toemail, $fromemail, $getdetails = false){
    $email_arr = explode("@", $toemail);
    $domain = array_slice($email_arr, -1);
    $domain = $domain[0];
    // Trim [ and ] from beginning and end of domain string, respectively
    $domain = ltrim($domain, "[");
    $domain = rtrim($domain, "]");
    if( "IPv6:" == substr($domain, 0, strlen("IPv6:")) ) {
        $domain = substr($domain, strlen("IPv6") + 1);
    }
    $mxhosts = array();
    if( filter_var($domain, FILTER_VALIDATE_IP) )
        $mx_ip = $domain;
    else
        getmxrr($domain, $mxhosts, $mxweight);
    if(!empty($mxhosts) )
        $mx_ip = $mxhosts[array_search(min($mxweight), $mxhosts)];
    else {
        if( filter_var($domain, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4) ) {
            $record_a = dns_get_record($domain, DNS_A);
        }
        elseif( filter_var($domain, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6) ) {
            $record_a = dns_get_record($domain, DNS_AAAA);
        }
        if( !empty($record_a) )
            $mx_ip = $record_a[0]['ip'];
        else {
            $result   = "invalid";
            $details .= "No suitable MX records found.";
            return ( (true == $getdetails) ? array($result, $details) : $result );
        }
    }

    $connect = @fsockopen($mx_ip, 25); 
    if($connect){ 
        if(preg_match("/^220/i", $out = fgets($connect, 1024))){
            fputs ($connect , "HELO $mx_ip\r\n"); 
            $out = fgets ($connect, 1024);
            $details .= $out."\n";

            fputs ($connect , "MAIL FROM: <$fromemail>\r\n"); 
            $from = fgets ($connect, 1024); 
            $details .= $from."\n";
            fputs ($connect , "RCPT TO: <$toemail>\r\n"); 
            $to = fgets ($connect, 1024);
            $details .= $to."\n";
            fputs ($connect , "QUIT"); 
            fclose($connect);
            if(!preg_match("/^250/i", $from) || !preg_match("/^250/i", $to)){
                $result = "invalid"; 
            }
            else{
                $result = "valid";
            }
        } 
    }
    else{
        $result = "invalid";
        $details .= "Could not connect to server";
    }
    if($getdetails){
        return array($result, $details);
    }
    else{
        return $result;
    }
}
?>

如果您有更好的想法,请帮助我。

4

1 回答 1

2

DNS 查找不会导致列入黑名单。但是它对您的 DNS 服务的质量非常敏感 - 我最近开始使用net_dns2而不是 getmxrr() 因为后者不区分超时、NXDOMAIN 和其他错误(不幸的是,这里的 DNS 服务器是由我们配置的“专家”)。

(知道我使用 curl_multi_*() 函数来运行并发查找也可能会有所帮助 - 处理大列表可能需要很长时间-在此处描述)。

探测 MX 很可能会导致您被列入黑名单 - 作为可交付性的衡量标准,这主要是浪费时间(并且由于您使用的脚本显式解析每个 MX 的 IP 地址,在性能方面有些昂贵)。此外,如果主 MX 不可用(SMTP 设计为异步),则会导致误报。

另一种解决方案,减少误报(与您描述的方法相比,误报)是使用反弹处理程序,尽管这是以做出确定的一些延迟为代价的。

我还建议(取决于处理列表所需的时间)您使用正则表达式预先验证电子邮件地址 - 但要注意在互联网上有很多不好的例子说明如何做到这一点。

于 2016-06-06T11:37:16.117 回答