SQL Server
SQL Server
Duplicate OpensSSL to Create Signature using Cert and Key Files
See more OpenSSL Examples
This example duplicates the following:openssl smime –sign -in something.xml -out something.der -signer mycert.crt -inkey cert.key -outform der –nodetach
Note: Although "smime" is the OpenSSL command, it's not actually producing S/MIME. The arguments "-outform der -binary" indicates that the output is binary DER (i.e. the PKCS7 binary signature). The input can be any type of file: XML, PDF, JPG, ... *anything*...
Chilkat SQL Server Downloads
-- 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)
DECLARE @success int
SELECT @success = 0
-- This example requires the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
DECLARE @crypt int
EXEC @hr = sp_OACreate 'Chilkat.Crypt2', @crypt OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
-- Load the cert and private key from separate files.
DECLARE @cert int
EXEC @hr = sp_OACreate 'Chilkat.Cert', @cert OUT
EXEC sp_OAMethod @cert, 'LoadFromFile', @success OUT, 'myCert.crt'
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @cert, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @crypt
EXEC @hr = sp_OADestroy @cert
RETURN
END
DECLARE @bd int
EXEC @hr = sp_OACreate 'Chilkat.BinData', @bd OUT
EXEC sp_OAMethod @bd, 'LoadFile', @success OUT, 'cert.key'
DECLARE @privkey int
EXEC @hr = sp_OACreate 'Chilkat.PrivateKey', @privkey OUT
-- Load from any format private key.
-- If the file does not need a password, the 2nd arg is ignored.
EXEC sp_OAMethod @privkey, 'LoadAnyFormat', @success OUT, @bd, 'password_if_needed'
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @privkey, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @crypt
EXEC @hr = sp_OADestroy @cert
EXEC @hr = sp_OADestroy @bd
EXEC @hr = sp_OADestroy @privkey
RETURN
END
EXEC sp_OAMethod @crypt, 'SetSigningCert2', @success OUT, @cert, @privkey
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @crypt, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @crypt
EXEC @hr = sp_OADestroy @cert
EXEC @hr = sp_OADestroy @bd
EXEC @hr = sp_OADestroy @privkey
RETURN
END
-- Create the opaque signature (PKCS7 binary DER that contains both the signature and original file data).
EXEC sp_OAMethod @crypt, 'CreateP7M', @success OUT, 'qa_data/infile.anything', 'qa_output/outfile.der'
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @crypt, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @crypt
EXEC @hr = sp_OADestroy @cert
EXEC @hr = sp_OADestroy @bd
EXEC @hr = sp_OADestroy @privkey
RETURN
END
PRINT 'Success.'
EXEC @hr = sp_OADestroy @crypt
EXEC @hr = sp_OADestroy @cert
EXEC @hr = sp_OADestroy @bd
EXEC @hr = sp_OADestroy @privkey
END
GO