Crypto++ 8.7
Free C++ class library of cryptographic schemes
|
SHA-256 message digest. More...
#include <sha.h>
Public Member Functions | |
std::string | AlgorithmProvider () const |
Retrieve the provider of this algorithm. More... | |
Public Member Functions inherited from IteratedHashWithStaticTransform< word32, BigEndian, 64, 32, SHA256, 32, true > | |
unsigned int | DigestSize () const |
Provides the digest size of the hash. More... | |
Public Member Functions inherited from ClonableImpl< SHA256, AlgorithmImpl< IteratedHash< word32, BigEndian, T_BlockSize >, SHA256 > > | |
Clonable * | Clone () const |
Create a copy of this object. More... | |
Public Member Functions inherited from AlgorithmImpl< IteratedHash< word32, BigEndian, T_BlockSize >, SHA256 > | |
std::string | AlgorithmName () const |
The algorithm name. More... | |
Public Member Functions inherited from IteratedHash< word32, BigEndian, T_BlockSize > | |
unsigned int | BlockSize () const |
Provides the block size of the hash. More... | |
ByteOrder | GetByteOrder () const |
Provides the byte order of the hash. More... | |
void | CorrectEndianess (HashWordType *out, const HashWordType *in, size_t byteCount) |
Adjusts the byte ordering of the hash. More... | |
Public Member Functions inherited from IteratedHashBase< word32, HashTransformation > | |
IteratedHashBase () | |
Construct an IteratedHashBase. More... | |
unsigned int | OptimalBlockSize () const |
Provides the input block size most efficient for this cipher. More... | |
unsigned int | OptimalDataAlignment () const |
Provides input and output data alignment for optimal performance. More... | |
void | Update (const byte *input, size_t length) |
Updates a hash with additional input. More... | |
byte * | CreateUpdateSpace (size_t &size) |
Requests space which can be written into by the caller. More... | |
void | Restart () |
Restart the hash. More... | |
void | TruncatedFinal (byte *digest, size_t digestSize) |
Computes the hash of the current message. More... | |
virtual std::string | AlgorithmProvider () const |
Retrieve the provider of this algorithm. More... | |
Public Member Functions inherited from HashTransformation | |
HashTransformation & | Ref () |
Provides a reference to this object. More... | |
virtual void | Update (const byte *input, size_t length)=0 |
Updates a hash with additional input. More... | |
virtual byte * | CreateUpdateSpace (size_t &size) |
Request space which can be written into by the caller. More... | |
virtual void | Final (byte *digest) |
Computes the hash of the current message. More... | |
virtual void | Restart () |
Restart the hash. More... | |
virtual unsigned int | DigestSize () const =0 |
Provides the digest size of the hash. More... | |
unsigned int | TagSize () const |
Provides the tag size of the hash. More... | |
virtual unsigned int | BlockSize () const |
Provides the block size of the compression function. More... | |
virtual unsigned int | OptimalBlockSize () const |
Provides the input block size most efficient for this hash. More... | |
virtual unsigned int | OptimalDataAlignment () const |
Provides input and output data alignment for optimal performance. More... | |
virtual void | CalculateDigest (byte *digest, const byte *input, size_t length) |
Updates the hash with additional input and computes the hash of the current message. More... | |
virtual bool | Verify (const byte *digest) |
Verifies the hash of the current message. More... | |
virtual bool | VerifyDigest (const byte *digest, const byte *input, size_t length) |
Updates the hash with additional input and verifies the hash of the current message. More... | |
virtual void | TruncatedFinal (byte *digest, size_t digestSize)=0 |
Computes the hash of the current message. More... | |
virtual void | CalculateTruncatedDigest (byte *digest, size_t digestSize, const byte *input, size_t length) |
Updates the hash with additional input and computes the hash of the current message. More... | |
virtual bool | TruncatedVerify (const byte *digest, size_t digestLength) |
Verifies the hash of the current message. More... | |
virtual bool | VerifyTruncatedDigest (const byte *digest, size_t digestLength, const byte *input, size_t length) |
Updates the hash with additional input and verifies the hash of the current message. More... | |
Public Member Functions inherited from Algorithm | |
Algorithm (bool checkSelfTestStatus=true) | |
Interface for all crypto algorithms. More... | |
virtual std::string | AlgorithmName () const |
Provides the name of this algorithm. More... | |
virtual std::string | AlgorithmProvider () const |
Retrieve the provider of this algorithm. More... | |
virtual Clonable * | Clone () const |
Copies this object. More... | |
Static Public Member Functions | |
static void | InitState (HashWordType *state) |
Initialize state array. More... | |
static void | Transform (HashWordType *digest, const HashWordType *data) |
Operate the hash. More... | |
static const char * | StaticAlgorithmName () |
The algorithm name. More... | |
Static Public Member Functions inherited from AlgorithmImpl< IteratedHash< word32, BigEndian, T_BlockSize >, SHA256 > | |
static std::string | StaticAlgorithmName () |
The algorithm name. More... | |
Additional Inherited Members | |
Public Types inherited from IteratedHash< word32, BigEndian, T_BlockSize > | |
typedef BigEndian | ByteOrderClass |
typedef word32 | HashWordType |
Public Types inherited from IteratedHashBase< word32, HashTransformation > | |
typedef word32 | HashWordType |
Static Public Attributes inherited from IteratedHashWithStaticTransform< word32, BigEndian, 64, 32, SHA256, 32, true > | |
static const int | DIGESTSIZE |
Static Public Attributes inherited from IteratedHash< word32, BigEndian, T_BlockSize > | |
static const int | BLOCKSIZE |
SHA-256 message digest.
|
static |
Initialize state array.
state | the state of the hash |
InitState sets a state array to SHA256 initial values
Hashes which derive from IteratedHashWithStaticTransform provide static member functions InitState and Transform. External classes, like SEAL and MDC, can initialize state with a user provided key and operate the hash on the data with the user supplied state.
|
static |
Operate the hash.
digest | the state of the hash |
data | the data to be digested |
Transform operates the hash on data
. When the call is invoked digest
holds initial state. Upon return digest
holds the hash or updated state.
Hashes which derive from IteratedHashWithStaticTransform provide static member functions InitState and Transform. External classes, like SEAL and MDC, can initialize state with a user provided key and operate the hash on the data with the user supplied state.
|
inlinestatic |
|
virtual |
Retrieve the provider of this algorithm.
The algorithm provider can be a name like "C++", "SSE", "NEON", "AESNI", "ARMv8" and "Power8". C++ is standard C++ code. Other labels, like SSE, usually indicate a specialized implementation using instructions from a higher instruction set architecture (ISA). Future labels may include external hardware like a hardware security module (HSM).
Reimplemented from IteratedHashBase< word32, HashTransformation >.