Я работаю над модулем vtiger CRM для извлечения электронной почты с почтового сервера с использованием php imap с различными применяемыми условиями.
$hostname = '{imap.gmail.com:993/ssl/novalidate-cert}';
$username = '[email protected]';
$password = 'mypswd';
$inbox = imap_open($hostname,$username,$password) or die('Cannot connect to Gmail: ' . imap_last_error());
$emails = imap_search($inbox,'FROM [email protected]');
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, я поставил условие, если он уже существует или нет в моей базе данных.
Других решений пока нет …