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
(PowerBuilder) Use HTTPS Client Certificate from .cer and .key FilesDemonstrates how to load a cert + private key from .cer and .key (base64) files and use it for mutual TLS authentication (client-side certificate).
integer li_rc oleobject loo_Http oleobject loo_Cert oleobject loo_PrivKey integer li_Success oleobject loo_Bd // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. loo_Http = create oleobject // Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 li_rc = loo_Http.ConnectToNewObject("Chilkat.Http") if li_rc < 0 then destroy loo_Http MessageBox("Error","Connecting to COM object failed") return end if loo_Cert = create oleobject // Use "Chilkat_9_5_0.Cert" for versions of Chilkat < 10.0.0 li_rc = loo_Cert.ConnectToNewObject("Chilkat.Cert") loo_PrivKey = create oleobject // Use "Chilkat_9_5_0.PrivateKey" for versions of Chilkat < 10.0.0 li_rc = loo_PrivKey.ConnectToNewObject("Chilkat.PrivateKey") // Load any type of certificate (.cer, .p7b, .pem, etc.) by calling LoadFromFile. li_Success = loo_Cert.LoadFromFile("qa_data/certs/sample_cert_a.cer") if li_Success <> 1 then Write-Debug loo_Cert.LastErrorText destroy loo_Http destroy loo_Cert destroy loo_PrivKey return end if // Load the private key. loo_Bd = create oleobject // Use "Chilkat_9_5_0.BinData" for versions of Chilkat < 10.0.0 li_rc = loo_Bd.ConnectToNewObject("Chilkat.BinData") li_Success = loo_Bd.LoadFile("qa_data/certs/sample_key_a.key") li_Success = loo_PrivKey.LoadAnyFormat(loo_Bd,"privateKeyPasswordIfNecessary") if li_Success <> 1 then Write-Debug loo_PrivKey.LastErrorText destroy loo_Http destroy loo_Cert destroy loo_PrivKey destroy loo_Bd return end if // Associate the private key with the cert. li_Success = loo_Cert.SetPrivateKey(loo_PrivKey) if li_Success <> 1 then Write-Debug loo_Cert.LastErrorText destroy loo_Http destroy loo_Cert destroy loo_PrivKey destroy loo_Bd return end if // Set the certificate to be used for mutual TLS authentication // (i.e. sets the client-side certificate for two-way TLS authentication) li_Success = loo_Http.SetSslClientCert(loo_Cert) if li_Success <> 1 then Write-Debug loo_Http.LastErrorText destroy loo_Http destroy loo_Cert destroy loo_PrivKey destroy loo_Bd return end if // At this point, the HTTP object instance is setup with the client-side cert, and any SSL/TLS // connection will automatically use it if the server demands a client-side cert. destroy loo_Http destroy loo_Cert destroy loo_PrivKey destroy loo_Bd |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.