![]() |
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
(SQL Server) Get PDF Signer CertsSee more PDF Signatures ExamplesThis example demonstrates how to validate the signatures in a PDF and also shows how to get each signature's signer certificate.Note: This example requires Chilkat v9.5.0.87 or greater.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. DECLARE @pdf int -- Use "Chilkat_9_5_0.Pdf" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Pdf', @pdf OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Load a PDF that has cryptographic signatures to be validated DECLARE @success int EXEC sp_OAMethod @pdf, 'LoadFile', @success OUT, 'qa_data/pdf/sign_testing_1/helloSigned2.pdf' IF @success = 0 BEGIN EXEC sp_OAGetProperty @pdf, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @pdf RETURN END -- Each time we verify a signature, information about the signature is written into -- sigInfo (replacing whatever sigInfo previously contained). DECLARE @sigInfo int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @sigInfo OUT -- Iterate over each signature and validate each. DECLARE @numSignatures int EXEC sp_OAGetProperty @pdf, 'NumSignatures', @numSignatures OUT DECLARE @validated int SELECT @validated = 0 DECLARE @cert int -- Use "Chilkat_9_5_0.Cert" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Cert', @cert OUT DECLARE @i int SELECT @i = 0 WHILE @i < @numSignatures BEGIN EXEC sp_OAMethod @pdf, 'VerifySignature', @validated OUT, @i, @sigInfo PRINT 'Signature ' + @i + ' validated: ' + @validated -- The GetSignerCert method was added in Chilkat v9.5.0.87 -- After calling VerifySignature, you can get the signer certificate by calling -- GetSignerCert with the same index. EXEC sp_OAMethod @pdf, 'GetSignerCert', @success OUT, @i, @cert IF @success <> 0 BEGIN EXEC sp_OAGetProperty @cert, 'SubjectDN', @sTmp0 OUT PRINT 'PDF signer certificate: ' + @sTmp0 END SELECT @i = @i + 1 END PRINT 'Finished.' EXEC @hr = sp_OADestroy @pdf EXEC @hr = sp_OADestroy @sigInfo EXEC @hr = sp_OADestroy @cert END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.