如何使用PHP IMAP获取未存储在我们数据库中的电子邮件



我正在使用具有不同应用条件的PHP IMAP从邮件服务器中获取电子邮件的Vtiger CRM模块。

$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;
} 

此完整的代码工作正常,但是只想获取未存储在我的数据库中的新电子邮件,因此一旦将电子邮件存储在我的数据库中,就不应再次存储。

解决了问题,我使用日期参数过滤,以获取最低电子邮件,然后将message_id存储在我的数据库中,并使用此Message_ID我放置了一个条件,是否已经存在于我的条件数据库。

相关内容

最新更新