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) RSA Sign String using Private Key of Certificate Type A3 (smart card / token)Demonstrates RSA signing a string using the private key of a certificate type A3 (smart card, token). Note: This is a Windows-only example.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- First get the A3 certificate that was installed on the Windows system. DECLARE @certStore int -- Use "Chilkat_9_5_0.CertStore" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.CertStore', @certStore OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @thumbprint nvarchar(4000) SELECT @thumbprint = '12c1dd8015f3f03f7b1fa619dc24e2493ca8b4b2' -- This is specific to Windows because it is opening the Windows Current-User certificate store. DECLARE @bReadOnly int SELECT @bReadOnly = 1 DECLARE @success int EXEC sp_OAMethod @certStore, 'OpenCurrentUserStore', @success OUT, @bReadOnly IF @success <> 1 BEGIN EXEC sp_OAGetProperty @certStore, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @certStore RETURN END -- Find the certificate with the desired thumbprint -- (There are many ways to locate a certificate. This example chooses to find by thumbprint.) DECLARE @cert int EXEC sp_OAMethod @certStore, 'FindCertBySha1Thumbprint', @cert OUT, @thumbprint EXEC sp_OAGetProperty @certStore, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 <> 1 BEGIN PRINT 'Failed to find the certificate.' EXEC @hr = sp_OADestroy @certStore RETURN END EXEC sp_OAGetProperty @cert, 'SubjectCN', @sTmp0 OUT PRINT 'Found: ' + @sTmp0 DECLARE @rsa int -- Use "Chilkat_9_5_0.Rsa" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Rsa', @rsa OUT -- Provide the cert's private key DECLARE @bUsePrivateKey int SELECT @bUsePrivateKey = 1 EXEC sp_OAMethod @rsa, 'SetX509Cert', @success OUT, @cert, @bUsePrivateKey EXEC @hr = sp_OADestroy @cert IF @success <> 1 BEGIN EXEC sp_OAGetProperty @rsa, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @certStore EXEC @hr = sp_OADestroy @rsa RETURN END -- Return the RSA signature in base64 encoded form. EXEC sp_OASetProperty @rsa, 'EncodingMode', 'base64' -- Sign the utf-8 byte representation of the string. EXEC sp_OASetProperty @rsa, 'Charset', 'utf-8' -- You can also choose other hash algorithms, such as SHA-1. DECLARE @sigBase64 nvarchar(4000) EXEC sp_OAMethod @rsa, 'SignStringENC', @sigBase64 OUT, 'text to sign', 'SHA-256' EXEC sp_OAGetProperty @rsa, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 <> 1 BEGIN EXEC sp_OAGetProperty @rsa, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @certStore EXEC @hr = sp_OADestroy @rsa RETURN END PRINT 'Base64 signature: ' + @sigBase64 EXEC @hr = sp_OADestroy @certStore EXEC @hr = sp_OADestroy @rsa END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.