Unicode C++
Unicode C++
SFTP use Cert's Private Key for Authentication (Windows)
See more SFTP Examples
Demonstrates how to use the private key of a pre-installed certificate (on Windows) for SFTP authentication. The certificate's private key must be marked as "exportable" when originally installed.Chilkat Unicode C++ Downloads
#include <CkCertW.h>
#include <CkPrivateKeyW.h>
#include <CkSshKeyW.h>
#include <CkSFtpW.h>
void ChilkatSample(void)
{
bool success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkCertW cert;
// Load the certificate from the Windows certificate store
success = cert.LoadByCommonName(L"my_cert_common_name");
if (success == false) {
wprintf(L"%s\n",cert.lastErrorText());
return;
}
// Get the private key.
CkPrivateKeyW privKey;
success = cert.GetPrivateKey(privKey);
if (success == false) {
wprintf(L"%s\n",cert.lastErrorText());
return;
}
const wchar_t *privKeyPem = privKey.getPkcs8Pem();
if (privKey.get_LastMethodSuccess() == false) {
wprintf(L"%s\n",privKey.lastErrorText());
return;
}
CkSshKeyW sshKey;
success = sshKey.FromOpenSshPrivateKey(privKeyPem);
if (success == false) {
wprintf(L"%s\n",sshKey.lastErrorText());
return;
}
// Connect to an SSH/SFTP server
CkSFtpW sftp;
success = sftp.Connect(L"sftp.example.com",22);
if (success == false) {
wprintf(L"%s\n",sftp.lastErrorText());
return;
}
// Authenticate with the SSH server using a username + private key.
// (The private key serves as the password. The username identifies
// the SSH user account on the server.)
success = sftp.AuthenticatePk(L"mySshLogin",sshKey);
if (success == false) {
wprintf(L"%s\n",sftp.lastErrorText());
return;
}
wprintf(L"OK, the connection and authentication with the SSH server is completed.\n");
// This example is only to show the connection + authentication using a private key associated with a certificate in the Windows certificate store...
}