|  | 
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) SMTP SSH Tunneling (Port Forwarding)Demonstrates how to setup an SSH tunnel for SMTP. This example connects to an SMTP sever via an SSH tunnel and sends an email. 
 #include <C_CkMailManW.h> #include <C_CkEmailW.h> void ChilkatSample(void) { HCkMailManW mailman; const wchar_t *sshHostname; int sshPort; BOOL success; HCkEmailW email; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // The mailman object is used for sending (SMTP) and receiving (POP3) email. mailman = CkMailManW_Create(); // Connect to an SSH server and establish the SSH tunnel: // The SSH hostname may be a hostname or an // IP address, such as "192.168.1.108". // The port is typically 22 (the standard port for SSH). sshHostname = L"sftp.example.com"; sshPort = 22; success = CkMailManW_SshOpenTunnel(mailman,sshHostname,sshPort); if (success != TRUE) { wprintf(L"%s\n",CkMailManW_lastErrorText(mailman)); CkMailManW_Dispose(mailman); return; } // Authenticate with the SSH server via a login/password // or with a public key. // This example demonstrates SSH password authentication. // Note: This is not authenticating with the SMTP server, it is // for authenticating with the SSH server, which is separate. success = CkMailManW_SshAuthenticatePw(mailman,L"sshLogin",L"sshPassword"); if (success != TRUE) { wprintf(L"%s\n",CkMailManW_lastErrorText(mailman)); CkMailManW_Dispose(mailman); return; } // OK, the SSH tunnel is setup. The mailman may // be used exactly the same as usual, except all communications // are now sent through the SSH tunnel. // Set the SMTP server. CkMailManW_putSmtpHost(mailman,L"smtp.my-smtp-server.com"); // Set the SMTP login/password (if required) CkMailManW_putSmtpUsername(mailman,L"smtpLogin"); CkMailManW_putSmtpPassword(mailman,L"smtpPassword"); // Create a new email object email = CkEmailW_Create(); CkEmailW_putSubject(email,L"This is a test"); CkEmailW_putBody(email,L"This is a test"); CkEmailW_putFrom(email,L"Chilkat Support <support@chilkatsoft.com>"); success = CkEmailW_AddTo(email,L"Chilkat Admin",L"admin@chilkatsoft.com"); // The call to SendEmail automatically connects to the SMTP // server via the SSH tunnel (if not already connected). // Because the SSH tunnel has been previously setup, // this does not establish a direct connection with the SMTP // server. It directs the SSH server to establish the connection. // After SendEmail completes, the connection (i.e. session) remains // open so that subsequent SendEmail calls may use the // same SSH tunnel. success = CkMailManW_SendEmail(mailman,email); if (success != TRUE) { wprintf(L"%s\n",CkMailManW_lastErrorText(mailman)); CkMailManW_Dispose(mailman); CkEmailW_Dispose(email); return; } // If you're curious, have a look at LastErrorText after // a successful send. You'll see detailed information that // confirms the SSH tunneling. wprintf(L"%s\n",CkMailManW_lastErrorText(mailman)); // Note: Some SMTP servers do not actually send the email until // the connection is closed. In these cases, it is necessary to // call CloseSmtpConnection for the mail to be sent. // Most SMTP servers send the email immediately, and it is // not required to close the connection. wprintf(L"Mail Sent!\n"); CkMailManW_Dispose(mailman); CkEmailW_Dispose(email); } | ||||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.