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 ECC Private Key in JWK Format (JSON Web Key)Demonstrates how to get an ECC private key in JWK (JSON Web Key) format. Note: This example requires Chilkat v9.5.0.66 or later.
-- 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) -- Note: This example requires Chilkat v9.5.0.66 or later. -- Load a PEM file into memory. DECLARE @sbPem int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbPem OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int EXEC sp_OAMethod @sbPem, 'LoadFile', @success OUT, 'qa_data/pem/ecc_privKey.pem', 'utf-8' IF @success <> 1 BEGIN PRINT 'Failed to load PEM file.' EXEC @hr = sp_OADestroy @sbPem RETURN END -- Load the PEM into a private key object. DECLARE @privKey int -- Use "Chilkat_9_5_0.PrivateKey" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.PrivateKey', @privKey OUT EXEC sp_OAMethod @sbPem, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @privKey, 'LoadPem', @success OUT, @sTmp0 IF @success <> 1 BEGIN EXEC sp_OAGetProperty @privKey, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @sbPem EXEC @hr = sp_OADestroy @privKey RETURN END -- Get the private key in JWK format: DECLARE @jwk nvarchar(4000) EXEC sp_OAMethod @privKey, 'GetJwk', @jwk OUT -- The GetJwk method will return the JWK in the most compact JSON format possible, -- as a single line with no extra whitespace. To get a more human-readable JWK (for this example), -- load into a Chilkat JSON object and emit non-compact: DECLARE @json int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT EXEC sp_OAMethod @json, 'Load', @success OUT, @jwk EXEC sp_OASetProperty @json, 'EmitCompact', 0 PRINT 'ECC Private Key in JWK format:' EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- Sample output: -- { -- "kty": "EC", -- "crv": "P-256", -- "x": "oBUyo8CQAFPeYPvv78ylh5MwFZjTCLQeb042TjiMJxE", -- "y": "vvQyxZkUjJQUPU_0bCy3Pj5qQdfu8jwEfqEeYGZ95CU", -- "d": "EbVzfPnZPxfAyxqEZV05laAoJAl-_6Xt2O4mOB611sM" -- } -- -- Additional information can be added like this: EXEC sp_OAMethod @json, 'AppendString', @success OUT, 'use', 'enc' EXEC sp_OAMethod @json, 'AppendString', @success OUT, 'kid', '123ABC' -- Now examine the JSON: EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- { -- "kty": "EC", -- "crv": "P-256", -- "x": "oBUyo8CQAFPeYPvv78ylh5MwFZjTCLQeb042TjiMJxE", -- "y": "vvQyxZkUjJQUPU_0bCy3Pj5qQdfu8jwEfqEeYGZ95CU", -- "d": "EbVzfPnZPxfAyxqEZV05laAoJAl-_6Xt2O4mOB611sM", -- "use": "enc", -- "kid": "123ABC" -- } EXEC @hr = sp_OADestroy @sbPem EXEC @hr = sp_OADestroy @privKey EXEC @hr = sp_OADestroy @json END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.