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
(Tcl) Duplicate openssl dgst -sha256 -verify pubKey.pem -signature signature.sig in.datDemonstrates how to duplicate this OpenSSL command: openssl dgst -sha256 -verify pubKey.pem -signature signature.sig in.datThe in.dat file contains the original data that was signed, and can contain text or binary data of any type. The above OpenSSL command does the following:
load ./chilkat.dll # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set pubKey [new_CkPublicKey] # Load the public key from an PEM file: set success [CkPublicKey_LoadFromFile $pubKey "pubKey.pem"] if {$success != 1} then { puts [CkPublicKey_lastErrorText $pubKey] delete_CkPublicKey $pubKey exit } # Load the data of the original file that was signed. set bdFileData [new_CkBinData] set success [CkBinData_LoadFile $bdFileData "in.dat"] # Load the signature. set bdSig [new_CkBinData] set success [CkBinData_LoadFile $bdSig "signature.sig"] set rsa [new_CkRsa] # Import the public key into the RSA component: set success [CkRsa_ImportPublicKeyObj $rsa $pubKey] if {$success != 1} then { puts [CkRsa_lastErrorText $rsa] delete_CkPublicKey $pubKey delete_CkBinData $bdFileData delete_CkBinData $bdSig delete_CkRsa $rsa exit } # OpenSSL uses big-endian. CkRsa_put_LittleEndian $rsa 0 set success [CkRsa_VerifyBd $rsa $bdFileData "sha256" $bdSig] if {$success != 1} then { puts [CkRsa_lastErrorText $rsa] puts "The signature was invalid." delete_CkPublicKey $pubKey delete_CkBinData $bdFileData delete_CkBinData $bdSig delete_CkRsa $rsa exit } puts "The signature was verified." delete_CkPublicKey $pubKey delete_CkBinData $bdFileData delete_CkBinData $bdSig delete_CkRsa $rsa |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.