我正在使用具有不同应用条件的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我放置了一个条件,是否已经存在于我的条件数据库。