[英]How to fetch emails those are not stored in our database using php imap
我正在使用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;
}
完整的代碼可以正常工作,但是只想獲取尚未存儲到我的數據庫中的新電子郵件,因此,一旦電子郵件存儲在我的數據庫中,就不應再次存儲。
問題解決了,我使用日期參數進行了過濾,以便它獲取最少的電子郵件,然后將message_id存儲到我的數據庫中,並使用此message_id對數據庫中是否存在該條件進行了設置。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.