DataFlex
DataFlex
Use Installed Cert on Windows for TLS Client Authentication
See more HTTP Examples
Demonstrates how to use a certificate that has already been installed on a Windows PC for TLS client authentication.Chilkat DataFlex Downloads
Use ChilkatAx-win32.pkg
Procedure Test
Boolean iSuccess
Handle hoHttp
Variant vCert
Handle hoCert
String sTemp1
Boolean bTemp1
Move False To iSuccess
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
Get Create (RefClass(cComChilkatHttp)) To hoHttp
If (Not(IsComObjectCreated(hoHttp))) Begin
Send CreateComObject of hoHttp
End
// On Windows, a pre-installed certificate can be loaded in a number of different ways.
// This example loads by the common name:
Get Create (RefClass(cComChilkatCert)) To hoCert
If (Not(IsComObjectCreated(hoCert))) Begin
Send CreateComObject of hoCert
End
Get ComLoadByCommonName Of hoCert "My ECA Medium Assurance Identity Certificate" To iSuccess
If (iSuccess <> True) Begin
Get ComLastErrorText Of hoCert To sTemp1
Showln sTemp1
Procedure_Return
End
// Make sure this certificate has a private key available.
// It should be a private key such that when the certificate was installed, it was marked as "exportable"
// so that authorized programs are able to access the private key.
Get ComHasPrivateKey Of hoCert To bTemp1
If (bTemp1 <> True) Begin
Showln "A private key is needed for TLS client authentication."
Showln "This certificate has no private key."
Procedure_Return
End
// Set the certificate to be used for mutual TLS authentication
// (i.e. sets the client-side certificate for two-way TLS authentication)
Get pvComObject of hoCert to vCert
Get ComSetSslClientCert Of hoHttp vCert To iSuccess
If (iSuccess <> True) Begin
Get ComLastErrorText Of hoHttp To sTemp1
Showln sTemp1
Procedure_Return
End
// 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.
End_Procedure