Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Unicode C++) Search IMAP Mailbox for Email Matching CriteriaSearching an IMAP mailbox for messages that match search criteria.
#include <CkImapW.h> #include <CkMessageSetW.h> #include <CkEmailBundleW.h> #include <CkEmailW.h> void ChilkatSample(void) { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkImapW imap; // Connect to an IMAP server. // Use TLS imap.put_Ssl(true); imap.put_Port(993); bool success = imap.Connect(L"imap.someMailServer.com"); if (success != true) { wprintf(L"%s\n",imap.lastErrorText()); return; } // Login success = imap.Login(L"myLogin",L"myPassword"); if (success != true) { wprintf(L"%s\n",imap.lastErrorText()); return; } // Select an IMAP mailbox success = imap.SelectMailbox(L"Inbox"); if (success != true) { wprintf(L"%s\n",imap.lastErrorText()); return; } CkMessageSetW *messageSet = 0; // We can choose to fetch UIDs or sequence numbers. bool fetchUids = true; // Here are examples of different search criteria: // Return all messages. const wchar_t *allMsgs = L"ALL"; // Search for already-answered emails. const wchar_t *answered = L"ANSWERED"; // Search for messages on a specific date. // The date string is DD-Month-YYYY where Month is // Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, or Dec. const wchar_t *onDate = L"SENTON 05-Mar-2007"; // Search for messages between two dates. SENTBEFORE // finds emails sent before a date, and SENTSINCE finds // email sent on or after a date. The "AND" operation // is implied by joining criteria, separated by spaces. const wchar_t *betweenDates = L"SENTSINCE 01-Mar-2007 SENTBEFORE 05-Mar-2007"; // Another example of AND: find all unanswered emails // sent after 04-Mar-2007 with "Problem" in the subject: const wchar_t *complexSearch1 = L"UNANSWERED SENTSINCE 04-Mar-2007 Subject \"Problem\""; // Find messages with a specific string in the body: const wchar_t *bodySearch = L"BODY \"problem solved\""; // Using OR. The syntax is OR <criteria1> <criteria2>. // The "OR" comes first, followed by each criteria. // For example, to match all emails with "Help" or "Question" in the subject. // You'll notice that literal strings may be quoted or unquoted. // If a literal contains SPACE characters, quote it: const wchar_t *orSearch = L"OR SUBJECT Help SUBJECT Question"; // ---------------------------------------------- // Strings are case-insensitive when searching.... // ---------------------------------------------- // Find all emails sent from yahoo.com addresses: const wchar_t *fromSearch = L"FROM yahoo.com"; // Find all emails sent from anyone with "John" in their name: const wchar_t *johnSearch = L"FROM John"; // Find emails with the RECENT flag set: const wchar_t *recentSearch = L"RECENT"; // Find emails that don't have the recent flag set: const wchar_t *notRecentSearch = L"NOT RECENT"; // This is synonymous with "OLD": const wchar_t *oldSearch = L"OLD"; // Find all emails marked for deletion: const wchar_t *markedForDeleteSearch = L"DELETED"; // Find all emails having a specified header field with a value // containing a substring: const wchar_t *headerSearch = L"HEADER DomainKey-Signature paypal.com"; // Find any emails having a specific header field. If the // 2nd argument to the "HEADER" criteria is an empty string, // any email having the header field is returned regardless // of the header field's content. // Find any emails with a DomainKey-Signature field: const wchar_t *headerExistsSearch = L"HEADER DomainKey-Signature \"\""; // Find NEW emails: these are emails that have the RECENT flag // set, but not the SEEN flag: const wchar_t *newSearch = L"NEW"; // Find emails larger than a certain number of bytes: const wchar_t *sizeLargerSearch = L"LARGER 500000"; // Find emails marked as seen or not already seen: const wchar_t *seenSearch = L"SEEN"; const wchar_t *notSeenSearch = L"NOT SEEN"; // Find emails having a given substring in the TO header field: const wchar_t *toSearch = L"TO support@chilkatsoft.com"; // A more long-winded way to do the same thing: const wchar_t *toSearch2 = L"HEADER TO support@chilkatsoft.com"; // Find emails smaller than a size in bytes: const wchar_t *smallerSearch = L"SMALLER 30000"; // Find emails that have a substring anywhere in the header // or body: const wchar_t *fullSubstringSearch = L"TEXT \"Zip Component\""; // Pass any of the above strings here to test a search: messageSet = imap.Search(orSearch,fetchUids); if (imap.get_LastMethodSuccess() == false) { wprintf(L"%s\n",imap.lastErrorText()); return; } // Fetch the email headers into a bundle object: CkEmailBundleW *bundle = 0; bundle = imap.FetchHeaders(*messageSet); if (imap.get_LastMethodSuccess() == false) { delete messageSet; wprintf(L"%s\n",imap.lastErrorText()); return; } // Display the Subject and From of each email. int i = 0; while (i < bundle->get_MessageCount()) { CkEmailW *email = 0; email = bundle->GetEmail(i); wprintf(L"%s\n",email->getHeaderField(L"Date")); wprintf(L"%s\n",email->subject()); wprintf(L"%s\n",email->ck_from()); wprintf(L"--\n"); delete email; i = i + 1; } // Disconnect from the IMAP server. success = imap.Disconnect(); delete messageSet; delete bundle; } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.