Chilkat
HOME
Android™
ASP
Visual Basic
VB.NET
C#
iOS (IPhone)
Objective-C
C++
C
MFC
Delphi
FoxPro
Java
Perl
PHP Extension
PHP ActiveX
Python
PowerShell
Ruby
SQL Server
VBScript
|
HMAC SHA-1 Matching FIPS ExamplesProvides an example of computing an HMAC-SHA1 digest to duplicate the FIPS examples at http://csrc.nist.gov/publications/fips/fips198/fips-198a.pdf
CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @sTmp0 nvarchar(4000) DECLARE @crypt int EXEC @hr = sp_OACreate 'Chilkat.Crypt2', @crypt OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int EXEC sp_OAMethod @crypt, 'UnlockComponent', @success OUT, 'Anything for 30-day trial.' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @crypt, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 RETURN END DECLARE @strToSign nvarchar(4000) SELECT @strToSign = 'Sample #1' -- 64-byte key DECLARE @key nvarchar(4000) SELECT @key = '000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f' -- The expected result: -- (from Appendix A.1 at http://csrc.nist.gov/publications/fips/fips198/fips-198a.pdf ) DECLARE @expectedResult nvarchar(4000) SELECT @expectedResult = '4f4ca3d5d68ba7cc0a1208c9c61e9c5da0403c0a' -- Here is the code to duplicate the results: EXEC sp_OASetProperty @crypt, 'HashAlgorithm', 'sha-1' EXEC sp_OASetProperty @crypt, 'EncodingMode', 'hex' EXEC sp_OAMethod @crypt, 'SetHmacKeyEncoded', NULL, @key, 'hex' DECLARE @mac nvarchar(4000) EXEC sp_OAMethod @crypt, 'HmacStringENC', @mac OUT, @strToSign PRINT 'Computed: ' + @mac PRINT 'Expected: ' + @expectedResult END GO |
© 2000-2010 Chilkat Software, Inc. All Rights Reserved.