![]()  | 
  
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
 
      (Visual FoxPro) SSH Authentication using X.509 CertificatesSee more SSH ExamplesDemonstrates how to authenticate with an SSH/SFTP server using an certificate's private key.Note: See X.509v3 Certificates for SSH Authentication for more information. 
 LOCAL loSsh LOCAL lcHostname LOCAL lnPort LOCAL lnSuccess LOCAL loCert LOCAL lcPrivKeyPem LOCAL loKey * This example assumes the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Ssh') loSsh = CreateObject('Chilkat.Ssh') lcHostname = "ssh.example.com" lnPort = 22 lnSuccess = loSsh.Connect(lcHostname,lnPort) IF (lnSuccess <> 1) THEN ? loSsh.LastErrorText RELEASE loSsh CANCEL ENDIF * Load the cert + private key from a .pfx. * Note: Chilkat provides methods for loading certs and private keys from many sources, including smart cards and USB tokens (HSM's) * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Cert') loCert = CreateObject('Chilkat.Cert') lnSuccess = loCert.LoadPfxFile("qa_data/pfx/example.pfx","pfx_password") IF (lnSuccess <> 1) THEN ? loCert.LastErrorText RELEASE loSsh RELEASE loCert CANCEL ENDIF * Get the cert's private key (as PEM) to be used for SSH authentication. * (The public key is installed on the server.) lcPrivKeyPem = loCert.GetPrivateKeyPem() IF (loCert.LastMethodSuccess = 0) THEN ? loCert.LastErrorText RELEASE loSsh RELEASE loCert CANCEL ENDIF * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.SshKey') loKey = CreateObject('Chilkat.SshKey') * Load a private key from a PEM string: lnSuccess = loKey.FromOpenSshPrivateKey(lcPrivKeyPem) IF (lnSuccess <> 1) THEN ? loKey.LastErrorText RELEASE loSsh RELEASE loCert RELEASE loKey CANCEL ENDIF * Authenticate with the SSH server. lnSuccess = loSsh.AuthenticatePk("myLogin",loKey) IF (lnSuccess <> 1) THEN ? loSsh.LastErrorText RELEASE loSsh RELEASE loCert RELEASE loKey CANCEL ENDIF ? "Public-Key Authentication Successful!" RELEASE loSsh RELEASE loCert RELEASE loKey  | 
  ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.