Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) SFTP use Cert's Private Key from PFX (.pfx/.p12)Demonstrates how to use the private key associated with a certificate from a .pfx/.p12 file.
#import <CkoCert.h> #import <NSString.h> #import <CkoPrivateKey.h> #import <CkoSshKey.h> #import <CkoSFtp.h> // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoCert *cert = [[CkoCert alloc] init]; NSString *pfxFilepath = @"qa_data/pfx/my.pfx"; NSString *pfxPassword = @"secret"; // A PFX typically contains certificates in the chain of authentication. // The Chilkat cert object will choose the certificate w/ // private key farthest from the root authority cert. // To access all the certificates in a PFX, use the // Chilkat certificate store object instead. BOOL success = [cert LoadPfxFile: pfxFilepath password: pfxPassword]; if (success != YES) { NSLog(@"%@",cert.LastErrorText); return; } // Get the private key. CkoPrivateKey *privKey = [cert ExportPrivateKey]; if (cert.LastMethodSuccess == NO) { NSLog(@"%@",cert.LastErrorText); return; } NSString *privKeyPem = [privKey GetPkcs8Pem]; if (privKey.LastMethodSuccess == NO) { NSLog(@"%@",privKey.LastErrorText); return; } CkoSshKey *sshKey = [[CkoSshKey alloc] init]; success = [sshKey FromOpenSshPrivateKey: privKeyPem]; if (success == NO) { NSLog(@"%@",sshKey.LastErrorText); return; } // Connect to an SSH/SFTP server CkoSFtp *sftp = [[CkoSFtp alloc] init]; success = [sftp Connect: @"sftp.example.com" port: [NSNumber numberWithInt: 22]]; if (success == NO) { NSLog(@"%@",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: @"mySshLogin" privateKey: sshKey]; if (success == NO) { NSLog(@"%@",sftp.LastErrorText); return; } NSLog(@"%@",@"OK, the connection and authentication with the SSH server is completed."); // This example is only to show the connection + authentication using a private key associated with a certificate in the Windows certificate store... |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.