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
(Unicode C++) Examine SSL/TLS Server CertificateSee more Socket/SSL/TLS ExamplesDemonstrates how an application can examine and check a server's SSL/TLS certificate.
#include <CkSocketW.h> #include <CkCertW.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkSocketW socket; // Connect to a server. bool useTls = true; int maxWaitMs = 2000; bool success = socket.Connect(L"www.intel.com",443,useTls,maxWaitMs); if (success == false) { wprintf(L"%s\n",socket.lastErrorText()); return; } // If we get here, the TLS connection ws made.. // In any SSL/TLS handshake, the server sends its certificate in a TLS handshake message. // Chilkat will keep it cached within the object that made the connection. // Get the server's cert and examine a few things. CkCertW *cert = socket.GetSslServerCert(); if (socket.get_LastMethodSuccess() == false) { // This is unexpected.. wprintf(L"%s\n",socket.lastErrorText()); return; } wprintf(L"Distinguished Name: %s\n",cert->subjectDN()); wprintf(L"Common Name: %s\n",cert->subjectCN()); wprintf(L"Issuer Distinguished Name: %s\n",cert->issuerDN()); wprintf(L"Issuer Common Name: %s\n",cert->issuerCN()); wprintf(L"Expired: %d\n",cert->get_Expired()); wprintf(L"Revoked: %d\n",cert->get_Revoked()); wprintf(L"Signature Verified: %d\n",cert->get_SignatureVerified()); wprintf(L"Trusted Root: %d\n",cert->get_TrustedRoot()); // Sample output: // Distinguished Name: C=US, ST=California, O=Intel Corporation, CN=*.intel.com // Common Name: *.intel.com // Issuer Distinguished Name: C=GB, ST=Greater Manchester, L=Salford, O=Sectigo Limited, CN=Sectigo RSA Organization Validation Secure Server CA // Issuer Common Name: Sectigo RSA Organization Validation Secure Server CA // Expired: False // Revoked: False // Signature Verified: True // Trusted Root: True delete cert; } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.