|  | 
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
| (PowerShell) ECDSA Sign and Verify Data using Different Hash AlgorithmsDemonstrates how to create ECDSA signatures on data using different hash algorithms. Note: This example requires Chilkat v9.5.0.85 or greater because the SignBd and VerifyBd methods were added in v9.5.0.85. 
 Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll" # This example assumes the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # First load an ECDSA private key to be used for signing. $privKey = New-Object Chilkat.PrivateKey $success = $privKey.LoadEncryptedPemFile("qa_data/ecc/secp256r1-key-pkcs8-secret.pem","secret") if ($success -eq $false) { $($privKey.LastErrorText) exit } # Load some data to be signed. $bd = New-Object Chilkat.BinData $success = $bd.LoadFile("qa_data/hamlet.xml") if ($success -eq $false) { $("Failed to load file to be hashed.") exit } $ecdsa = New-Object Chilkat.Ecc $prng = New-Object Chilkat.Prng # Sign the sha256 hash of the data. Return the ECDSA signature in the base64 encoding. $("ECDSA signing the sha256 hash of the data...") $sig = $ecdsa.SignBd($bd,"sha256","base64",$privKey,$prng) $("sig = " + $sig) # Verify the signature against the original data. # (We must use the same hash algorithm that was used when signing.) # Load the public key that corresponds to the private key used for signing. $pubKey = New-Object Chilkat.PublicKey $success = $pubKey.LoadFromFile("qa_data/ecc/secp256r1-pub.pem") if ($success -eq $false) { $($pubKey.LastErrorText) exit } $ecc2 = New-Object Chilkat.Ecc $result = $ecc2.VerifyBd($bd,"sha256",$sig,"base64",$pubKey) if ($result -ne 1) { $($ecc2.LastErrorText) exit } $("Verified!") # ---------------------------------------------------------------------------------------- # Let's do the same thing, but with sha384 hashing... $("--------------------------------------------") $("ECDSA signing the sha384 hash of the data...") $sig = $ecdsa.SignBd($bd,"sha384","base64",$privKey,$prng) $("sig = " + $sig) $result = $ecc2.VerifyBd($bd,"sha384",$sig,"base64",$pubKey) if ($result -ne 1) { $($ecc2.LastErrorText) exit } $("Verified!") | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.