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 Basic 6.0) Backup Windows Current User / Personal Certificates to a .zipDemonstrates how to backup the certificates in the Windows registry-based Current User certificate store (in the "Personal" Logical Store as seen in certmgr.msc), to a zip archive. Certificates having an exportable private key are exported to .pfx files. Certificates with no private key, or with a non-exportable private key, are exported to .cer files. Obviously, this example only runs on Windows computers.
Dim certStore As New ChilkatCertStore Dim readOnly As Long readOnly = 1 Dim success As Long success = certStore.OpenCurrentUserStore(readOnly) If (Not success) Then Debug.Print certStore.LastErrorText Exit Sub End If Dim pfxPassword As String pfxPassword = "secret" Dim allSuccess As Long allSuccess = 1 Dim numSuccess As Long numSuccess = 0 Dim entry As ChilkatZipEntry Dim zip As New ChilkatZip success = zip.NewZip("qa_output/personalCerts.zip") Dim certData As New ChilkatBinData Dim sbFilename As New ChilkatStringBuilder ' Iterate over the certificates in the Current User store. Dim numCerts As Long numCerts = certStore.NumCertificates Dim i As Long i = 0 Do While i < numCerts Dim cert As ChilkatCert Set cert = certStore.GetCertificate(i) Debug.Print "DN = " & cert.SubjectDN success = sbFilename.SetString("cert") success = sbFilename.AppendInt(i + 1) Dim bHasPrivateKey As Long bHasPrivateKey = cert.HasPrivateKey() If ((bHasPrivateKey = 1) And (cert.PrivateKeyExportable = 1)) Then ' Export to a .pfx success = cert.ExportToPfxBd(pfxPassword,1,certData) If (success = 1) Then success = sbFilename.Append(".pfx") Set entry = zip.AppendBd(sbFilename.GetAsString(),certData) End If Else ' Export to a .cer success = cert.ExportCertDerBd(certData) If (success = 1) Then success = sbFilename.Append(".cer") Set entry = zip.AppendBd(sbFilename.GetAsString(),certData) End If End If If (success <> 1) Then allSuccess = 0 Else numSuccess = numSuccess + 1 End If i = i + 1 Loop If (numSuccess > 0) Then success = zip.WriteZipAndClose() If (success <> 1) Then Debug.Print zip.LastErrorText allSuccess = 0 End If End If Debug.Print "All success = " & allSuccess |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.