0

我正在开发 vtiger CRM 模块,用于使用具有不同应用条件的 php imap 从邮件服务器获取电子邮件。

$hostname = '{imap.gmail.com:993/ssl/novalidate-cert}';
$username = 'myemail@gmail.com';
$password = 'mypswd';

$inbox = imap_open($hostname,$username,$password) or die('Cannot connect to Gmail: ' . imap_last_error());  
$emails = imap_search($inbox,'FROM from@gmail.com');

if($emails) {

    $output = '';

    rsort($emails);

    foreach($emails as $email_number) {

        $overview = imap_fetch_overview($inbox,$email_number,0);
        $message = imap_fetchbody($inbox,$email_number,2);
        $message = trim(quoted_printable_decode($message));
        $output.= '<div class="toggler '.($overview[0]->seen ? 'read' : 'unread').'">';
        $output.= '<span class="subject">'.$overview[0]->subject.'</span> ';
        $output.= '<span class="from">'.$overview[0]->from.'</span>';
        $output.= '<span class="date">on '.$overview[0]->date.'</span>';
        $output.= '</div>';
        $output.= '<div class="body">'.$message.'</div>';
        echo $output;die;
    }

    echo $output;
} 

这个完整的代码运行良好,但只想获取尚未存储到我的数据库中的新电子邮件,因此一旦电子邮件存储在我的数据库中,它就不应该再次存储。

4

1 回答 1

1

问题解决了,我使用日期参数进行过滤,以便它获取最少的电子邮件,并将 message_id 存储到我的数据库中,并使用这个 message_id 设置一个条件,如果它在我的数据库中已经存在或不存在。

于 2017-02-16T12:56:14.460 回答