1

在我的服务器中,我通过 PHP 发送邮件,但我的邮件总是进入垃圾邮件文件夹。我做了 spf 记录的事情,但没关系。我也使用这个域的谷歌应用服务。请帮忙

邮件原件:

Delivered-To: mektup@gmail.com
Received: by 10.42.178.133 with SMTP id bm5cs95762icb;
        Fri, 31 Dec 2010 19:49:46 -0800 (PST)
Received: by 10.223.112.1 with SMTP id u1mr875459fap.109.1293853785941;
        Fri, 31 Dec 2010 19:49:45 -0800 (PST)
Return-Path: <apache@loft1397.serverloft.eu>
Received: from loft1397.serverloft.eu (loft1397.serverloft.eu [82.25.120.6])
        by mx.google.com with ESMTPS id 17si15455863fau.0.2010.12.31.19.49.45
        (version=TLSv1/SSLv3 cipher=RC4-MD5);
        Fri, 31 Dec 2010 19:49:45 -0800 (PST)
Received-SPF: pass (google.com: best guess record for domain of apache@loft1397.serverloft.eu designates 82.25.120.6 as permitted sender) client-ip=82.25.120.6;
Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of apache@loft1397.serverloft.eu designates 82.25.120.6 as permitted sender) smtp.mail=apache@loft1397.serverloft.eu
Received: from loft1397.serverloft.eu (unknown [127.0.0.1])
    by loft1397.serverloft.eu (Postfix) with ESMTP id 145B623A87F4
    for <mektup@gmail.com>; Sat,  1 Jan 2011 03:49:45 +0000 (UTC)
Received: by loft1397.serverloft.eu (Postfix, from userid 48)
    id EED7623A8831; Sat,  1 Jan 2011 03:49:44 +0000 (UTC)
To: mektup@gmail.com
Subject: Test mail
From: bilgi@xxxx.com
Message-Id: <20110101034944.EED7623A8831@loft1397.serverloft.eu>
Date: Sat,  1 Jan 2011 03:49:44 +0000 (UTC)

Hello! This is a simple email message.

域 SPF 记录: v=spf1 ip4:82.25.120.6 ip4:85.25.122.12 include:_spf.google.com ~all

4

3 回答 3

3

首先,为了长期解决这个问题,您可能做的最好的事情就是使用服务来发送您的电子邮件。它们有很多,但我听说过这三个的好消息:

还有一个应该很酷的新进入者,http://www.emailyak.com/,但它们仍处于测试阶段。所有服务都非常实惠,具有超级简单的 API,并且可能会立即解决您的问题。

如果这不是一个选项,或者如果您只是不想朝那个方向发展,那么您将需要生成(或让某人发送)垃圾邮件报告,以显示您的邮件为何进入他们的垃圾邮件文件夹。这是我从垃圾邮件刺客那里谈论的一个例子:

Content analysis details:   (7.9 points, 6.0 required)

pts rule name              description
---- ---------------------- --------------------------------------------------
3.2 FH_DATE_PAST_20XX      The date is grossly in the future.
1.1 DNS_FROM_OPENWHOIS     RBL: Envelope sender listed in bl.open-whois.org.
0.6 SPF_SOFTFAIL           SPF: sender does not match SPF record (softfail)
0.0 UNPARSEABLE_RELAY      Informational: message has unparseable relay lines
1.6 HTML_IMAGE_ONLY_28     BODY: HTML: images with 2400-2800 bytes of words
0.0 HTML_MESSAGE           BODY: HTML included in message
0.0 BAYES_50               BODY: Bayesian spam probability is 40 to 60%
                           [score: 0.5000]
1.5 MIME_HTML_ONLY         BODY: Message only has text/html MIME parts

获得此信息后,您可以诊断问题。我怀疑这与您的 SPF 记录有什么关系,但很难肯定,即使它们在标题中被列为“通过”。

祝你好运!

于 2011-01-01T04:10:44.677 回答
2

正如 Erick 所说,您的 SPF 声明为已通过,所以我会但它归结为您的 php 主函数中的标头格式错误

这是您拥有的代码:

<?php
$headers  = "MIME-Version: 1.0\r\n";
$headers .= "Content-type: text/html; charset=iso-8859-1\r\n";
$headers .= "From: UzmanKirala <bilgi@uzmankirala.com>\r\n";

$mail_body = "This<br />is<br />a<br />test<br />mail.";
mail('uzmankirala@hotmail.com', 'Subject', $mail_body, $headers);
?>

Google 将阅读此内容并查看邮件格式错误,因为没有边界。缺少正确的新行等。

我不会费心解释整个 RFC For the Email Formats,而是将您指向一个我一直使用并且运行良好的文件。

<?php
class Mail {
    protected $to;
    protected $from;
    protected $sender;
    protected $subject;
    protected $text;
    protected $html;
    protected $attachments = array();
    public $protocol = 'mail';
    public $hostname;
    public $username;
    public $password;
    public $port = 25;
    public $timeout = 5;
    public $newline = "\n";
    public $crlf = "\r\n";
    public $verp = FALSE;
    public $parameter = '';

    public function setTo($to) {
        $this->to = $to;
    }

    public function setFrom($from) {
        $this->from = $from;
    }

    public function addheader($header, $value) {
        $this->headers[$header] = $value;
    }

    public function setSender($sender) {
        $this->sender = html_entity_decode($sender, ENT_COMPAT, 'UTF-8');
    }

    public function setSubject($subject) {
        $this->subject = html_entity_decode($subject, ENT_COMPAT, 'UTF-8');
    }

    public function setText($text) {
        $this->text = $text;
    }

    public function setHtml($html) {
        $this->html = $html;
    }

    public function addAttachment($file, $filename = '') {
        if (!$filename) {
            $filename = basename($file);
        }

        $this->attachments[] = array(
            'filename' => $filename,
            'file'     => $file
        );
    }

    public function send() {
        if (!$this->to) {
            exit('Error: E-Mail to required!');
        }

        if (!$this->from) {
            exit('Error: E-Mail from required!');
        }

        if (!$this->sender) {
            exit('Error: E-Mail sender required!');
        }

        if (!$this->subject) {
            exit('Error: E-Mail subject required!');
        }

        if ((!$this->text) && (!$this->html)) {
            exit('Error: E-Mail message required!');
        }

        if (is_array($this->to)) {
            $to = implode(',', $this->to);
        } else {
            $to = $this->to;
        }

        $boundary = '----=_NextPart_' . md5(time());

        $header = '';

        if ($this->protocol != 'mail') {
            $header .= 'To: ' . $to . $this->newline;
            $header .= 'Subject: ' . $this->subject . $this->newline;
        }

        $header .= 'From: ' . $this->sender . '<' . $this->from . '>' . $this->newline;
        //$header .= 'From: "' . $this->sender . '" <' . $this->from . '>' . $this->newline;
        $header .= 'Reply-To: ' . $this->sender . '<' . $this->from . '>' . $this->newline;
        $header .= 'Return-Path: ' . $this->from . $this->newline;
        $header .= 'X-Mailer: PHP/' . phpversion() . $this->newline;
        $header .= 'MIME-Version: 1.0' . $this->newline;
        $header .= 'Content-Type: multipart/mixed; boundary="' . $boundary . '"' . $this->newline;

        if (!$this->html) {
            $message  = '--' . $boundary . $this->newline;
            $message .= 'Content-Type: text/plain; charset="utf-8"' . $this->newline;
            $message .= 'Content-Transfer-Encoding: 8bit' . $this->newline . $this->newline;
            $message .= $this->text . $this->newline;
        } else {
            $message  = '--' . $boundary . $this->newline;
            $message .= 'Content-Type: multipart/alternative; boundary="' . $boundary . '_alt"' . $this->newline . $this->newline;
            $message .= '--' . $boundary . '_alt' . $this->newline;
            $message .= 'Content-Type: text/plain; charset="utf-8"' . $this->newline;
            $message .= 'Content-Transfer-Encoding: 8bit' . $this->newline;

            if ($this->text) {
                $message .= $this->text . $this->newline;
            } else {
                $message .= 'This is a HTML email and your email client software does not support HTML email!' . $this->newline;
            }

            $message .= '--' . $boundary . '_alt' . $this->newline;
            $message .= 'Content-Type: text/html; charset="utf-8"' . $this->newline;
            $message .= 'Content-Transfer-Encoding: 8bit' . $this->newline . $this->newline;
            $message .= $this->html . $this->newline;
            $message .= '--' . $boundary . '_alt--' . $this->newline;
        }

        foreach ($this->attachments as $attachment) {
            if (file_exists($attachment['file'])) {
                $handle = fopen($attachment['file'], 'r');
                $content = fread($handle, filesize($attachment['file']));

                fclose($handle);

                $message .= '--' . $boundary . $this->newline;
                $message .= 'Content-Type: application/octetstream' . $this->newline;
                $message .= 'Content-Transfer-Encoding: base64' . $this->newline;
                $message .= 'Content-Disposition: attachment; filename="' . basename($attachment['filename']) . '"' . $this->newline;
                $message .= 'Content-ID: <' . basename($attachment['filename']) . '>' . $this->newline . $this->newline;
                $message .= chunk_split(base64_encode($content));
            }
        }

        $message .= '--' . $boundary . '--' . $this->newline;

        if ($this->protocol == 'mail') {
            ini_set('sendmail_from', $this->from);

            if ($this->parameter) {
                mail($to, $this->subject, $message, $header, $this->parameter);
            } else {
                mail($to, $this->subject, $message, $header);
            }

        } elseif ($this->protocol == 'smtp') {
            $handle = fsockopen($this->hostname, $this->port, $errno, $errstr, $this->timeout);

            if (!$handle) {
                error_log('Error: ' . $errstr . ' (' . $errno . ')');
            } else {
                if (substr(PHP_OS, 0, 3) != 'WIN') {
                    socket_set_timeout($handle, $this->timeout, 0);
                }

                while ($line = fgets($handle, 515)) {
                    if (substr($line, 3, 1) == ' ') {
                        break;
                    }
                }

                if (substr($this->hostname, 0, 3) == 'tls') {
                    fputs($handle, 'STARTTLS' . $this->crlf);

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if (substr($reply, 0, 3) != 220) {
                        error_log('Error: STARTTLS not accepted from server!');
                    }
                }

                if (!empty($this->username)  && !empty($this->password)) {
                    fputs($handle, 'EHLO ' . getenv('SERVER_NAME') . $this->crlf);

                    $reply = '';

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if (substr($reply, 0, 3) != 250) {
                        error_log('Error: EHLO not accepted from server!');
                    }

                    fputs($handle, 'AUTH LOGIN' . $this->crlf);

                    $reply = '';

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if (substr($reply, 0, 3) != 334) {
                        error_log('Error: AUTH LOGIN not accepted from server!');
                    }

                    fputs($handle, base64_encode($this->username) . $this->crlf);

                    $reply = '';

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if (substr($reply, 0, 3) != 334) {
                        error_log('Error: Username not accepted from server!');
                    }

                    fputs($handle, base64_encode($this->password) . $this->crlf);

                    $reply = '';

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if (substr($reply, 0, 3) != 235) {
                        error_log('Error: Password not accepted from server!');
                    }
                } else {
                    fputs($handle, 'HELO ' . getenv('SERVER_NAME') . $this->crlf);

                    $reply = '';

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if (substr($reply, 0, 3) != 250) {
                        error_log('Error: HELO not accepted from server!');
                    }
                }

                if ($this->verp) {
                    fputs($handle, 'MAIL FROM: <' . $this->from . '>XVERP' . $this->crlf);
                } else {
                    fputs($handle, 'MAIL FROM: <' . $this->from . '>' . $this->crlf);
                }

                $reply = '';

                while ($line = fgets($handle, 515)) {
                    $reply .= $line;

                    if (substr($line, 3, 1) == ' ') {
                        break;
                    }
                }

                if (substr($reply, 0, 3) != 250) {
                    error_log('Error: MAIL FROM not accepted from server!');
                }

                if (!is_array($this->to)) {
                    fputs($handle, 'RCPT TO: <' . $this->to . '>' . $this->crlf);

                    $reply = '';

                    while ($line = fgets($handle, 515)) {
                        $reply .= $line;

                        if (substr($line, 3, 1) == ' ') {
                            break;
                        }
                    }

                    if ((substr($reply, 0, 3) != 250) && (substr($reply, 0, 3) != 251)) {
                        error_log('Error: RCPT TO not accepted from server!');
                    }
                } else {
                    foreach ($this->to as $recipient) {
                        fputs($handle, 'RCPT TO: <' . $recipient . '>' . $this->crlf);

                        $reply = '';

                        while ($line = fgets($handle, 515)) {
                            $reply .= $line;

                            if (substr($line, 3, 1) == ' ') {
                                break;
                            }
                        }

                        if ((substr($reply, 0, 3) != 250) && (substr($reply, 0, 3) != 251)) {
                            error_log('Error: RCPT TO not accepted from server!');
                        }
                    }
                }

                fputs($handle, 'DATA' . $this->crlf);

                $reply = '';

                while ($line = fgets($handle, 515)) {
                    $reply .= $line;

                    if (substr($line, 3, 1) == ' ') {
                        break;
                    }
                }

                if (substr($reply, 0, 3) != 354) {
                    error_log('Error: DATA not accepted from server!');
                }

                fputs($handle, $header . $message . $this->crlf);
                fputs($handle, '.' . $this->crlf);

                $reply = '';

                while ($line = fgets($handle, 515)) {
                    $reply .= $line;

                    if (substr($line, 3, 1) == ' ') {
                        break;
                    }
                }

                if (substr($reply, 0, 3) != 250) {
                    error_log('Error: DATA not accepted from server!');
                }

                fputs($handle, 'QUIT' . $this->crlf);

                $reply = '';

                while ($line = fgets($handle, 515)) {
                    $reply .= $line;

                    if (substr($line, 3, 1) == ' ') {
                        break;
                    }
                }

                if (substr($reply, 0, 3) != 221) {
                    error_log('Error: QUIT not accepted from server!');
                }

                fclose($handle);
            }
        }
    }
}
?>

阅读类文件并了解如何充分使用它,但现在这里有一个入门示例:

$mail = new Mail();

$mail->setTo("mektup@gmail.com");
$mail->setFrom("bilgi@uzmankirala.com");
$mail->setSender("Bilgi");
$mail->setSubject("Test mail");
$mail->setHtml("<b>Some html email</b>");

$mail->send();
于 2011-01-01T04:23:07.527 回答
0

您是否进行了 DNS 设置以从您的站点发送邮件。如果不这样做,您的邮件接收者将无法识别您,从而将您的邮件发送到垃圾邮件。与您的托管支持人员联系,他们将指导您进行此类 DNS 设置。

于 2011-01-01T04:23:46.557 回答