![]() |
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
(Objective-C) SSH Authentication using an SSH CertificateSee more SSH ExamplesDemonstrates how to authenticate using an SSH certificate.Note: This example requires Chilkat v11.0.0 or greater. For more information, see https://www.chilkatsoft.com/understanding_ssh_certificates.asp
#import <CkoStringBuilder.h> #import <CkoSshKey.h> #import <CkoSsh.h> #import <NSString.h> // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoStringBuilder *sbSshCert = [[CkoStringBuilder alloc] init]; BOOL success = [sbSshCert LoadFile: @"qa_data/sshCert/user_ecdsa_key-cert.pub" charset: @"utf-8"]; if (success == NO) { NSLog(@"%@",@"Failed to load user_ecdsa_key-cert.pub"); return; } CkoStringBuilder *sbPrivKey = [[CkoStringBuilder alloc] init]; success = [sbPrivKey LoadFile: @"qa_data/sshKeys/user_ecdsa_key" charset: @"utf-8"]; if (success == NO) { NSLog(@"%@",@"Failed to load user_ecdsa_key"); return; } CkoSshKey *key = [[CkoSshKey alloc] init]; // Provide the password if the user_ecdsa_key is stored in an encrypted format. key.Password = @"secret"; success = [key FromOpenSshPrivateKey: [sbPrivKey GetAsString]]; if (success == NO) { NSLog(@"%@",key.LastErrorText); return; } // Indicate that the SSH certificate is to be used for authentication. // The UseSshCertificate method was added in Chilkat v11.0.0 [key UseSshCertificate: [sbSshCert GetAsString]]; CkoSsh *ssh = [[CkoSsh alloc] init]; NSString *hostname = @"ssh.example.com"; int port = 22; success = [ssh Connect: hostname port: [NSNumber numberWithInt: port]]; if (success != YES) { NSLog(@"%@",ssh.LastErrorText); return; } success = [ssh AuthenticatePk: @"myLogin" privateKey: key]; if (success != YES) { NSLog(@"%@",ssh.LastErrorText); return; } NSLog(@"%@",@"Public-Key Authentication using an SSH Certificate was Successful!"); |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.