Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) Client Certificate in RESTDemonstrates how to use a client certificate with a REST connection.
#include <CkRest.h> #include <CkSocket.h> void ChilkatSample(void) { CkString strOut; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // This example shows how to use the Chilkat socket object's connection. CkRest rest; CkSocket socket; // Set the certificate to be used for mutual TLS authentication // (i.e. sets the client-side certificate for two-way TLS authentication) // Note: There are other ways to set the client certificate using Chilkat. // For example, on Windows systems, a Chilkat certificate object could be loaded with certificate // pre-installed (with private key) in a Windows certificate store, and then socket.SetSslClientCert could be called. bool success = socket.SetSslClientCertPfx("/home/bob/pfxFiles/myClientSideCertWithPrivateKey.pfx","pfxPassword"); if (success != true) { strOut.append(socket.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Note: The certificate used for the client-side of TLS mutual authentication // must have the associated private key available. (.pfx/.p12 files typically store both // the certificate and associated private key.) // Establish the connection using the socket object (with client certificate authentication). bool bTls = true; int port = 443; int maxWaitMs = 5000; success = socket.Connect("www.example.com",port,bTls,maxWaitMs); if (success != true) { strOut.append("Connect Failure Error Code: "); strOut.appendInt(socket.get_ConnectFailReason()); strOut.append("\r\n"); strOut.append(socket.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } bool bAutoReconnect = true; // Use the connection: success = rest.UseConnection(socket,bAutoReconnect); if (success != true) { strOut.append(rest.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // At this point we are connected and can make REST calls... // For example.. const char *responseJson = rest.fullRequestNoBody("GET","/someQuery"); if (rest.get_LastMethodSuccess() != true) { strOut.append(rest.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.