Как получить электронные письма, которые не хранятся в нашей базе данных, используя php imap

Я работаю над модулем 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;
}

Этот полный код работает нормально, но я хочу получать только новые электронные письма, которые еще не сохранены в моей базе данных, так что, как только электронное письмо будет сохранено в моей базе данных, оно не будет сохранено снова.

0

Решение

Проблема решена, я отфильтровал, используя параметр даты, чтобы он получал минимальное количество электронных писем, и я сохранил message_id в своей базе данных, и, используя этот message_id, я поставил условие, если он уже существует или нет в моей базе данных.

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]