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++) Send GMail with BCC Recipients using REST APISee more GMail REST API ExamplesDemonstrates how to send an email with BCC recipients using the GMail REST API. Note: This example requires Chilkat v9.5.0.91 or greater.
#include <CkEmailW.h> #include <CkStringBuilderW.h> #include <CkJsonObjectW.h> #include <CkHttpW.h> #include <CkHttpResponseW.h> void ChilkatSample(void) { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. bool success; // Use the Chilkat Email API to create or load an email. CkEmailW email; // The From name/address don't need to be specified. // GMail will automatically use your Gmail address if the following 2 lines are omitted. email.put_FromName(L"My Name"); email.put_FromAddress(L"my_account_name@gmail.com"); email.AddTo(L"John Smith",L"somebody@somewhere.com"); // To add more recipients, make additional calls to AddTo or AddCC, one per recipient... // ----------------------------------------------------------------------------------------- // This section of this example demonstrates how to add BCC recipients. // // Technically, an email should never contain a "Bcc" MIME header because it would // effectively nullify the purpose of BCC -- which means "Blind Carbon Copy". // Email recipients should not be able to see the BCC recipients. // Chilkat never adds a "Bcc" header field. // However.. in this case, the GMail REST server will look for the Bcc header field, // and will include those email addresses when sending, and also removes the Bcc header // from the email that is sent. // // Starting in Chilkat v9.5.0.91, we can tell the email object to add the Bcc header // using the "UseBccHeader" UncommonOptions. For example: email.put_UncommonOptions(L"UseBccHeader"); email.AddBcc(L"Joe",L"joe@example.com"); email.AddBcc(L"Dave",L"dave@example.com"); // ... // ----------------------------------------------------------------------------------------- email.put_Subject(L"This is a test GMail email created using Chilkat."); email.put_Charset(L"utf-8"); email.AddPlainTextAlternativeBody(L"This is a test"); // Create an HTML email body with an embedded image. const wchar_t *cid = email.addRelatedFile(L"qa_data/jpg/starfish.jpg"); CkStringBuilderW sbHtml; sbHtml.Append(L"<html><body>This is a <b>test</b><br><img src=\"cid:STARFISH_CID\"/></body></html>"); int numReplacements = sbHtml.Replace(L"STARFISH_CID",cid); email.AddHtmlAlternativeBody(sbHtml.getAsString()); // OK.. we now have an HTML email with an embedded JPG image // We'll need to get the full MIME of the email encoded to a base64url string. CkStringBuilderW sbMime; email.GetMimeSb(sbMime); sbMime.Encode(L"base64url",L"utf-8"); // The body of the HTTP request will be JSON.. CkJsonObjectW json; json.UpdateSb(L"raw",sbMime); // Send the email... CkHttpW http; http.put_AuthToken(L"GMAIL-ACCESS-TOKEN"); const wchar_t *url = L"https://www.googleapis.com/gmail/v1/users/me/messages/send"; CkHttpResponseW *resp = http.PostJson3(url,L"application/json",json); if (http.get_LastMethodSuccess() != true) { wprintf(L"%s\n",http.lastErrorText()); return; } // A status code of 200 indicates success. wprintf(L"Response status code: %d\n",resp->get_StatusCode()); wprintf(L"Response body:\n"); wprintf(L"%s\n",resp->bodyStr()); delete resp; // The response body contains JSON. // Use the online tool at Generate JSON Parsing Code // to generate JSON parsing code. // A sample successful JSON response: // { // "id": "166f0d4ac39e50bf", // "threadId": "166f0d4ac39e50bf", // "labelIds": [ // "SENT" // ] // } } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.