Package org.bouncycastle.crypto.digests
Class SHA256Digest
- java.lang.Object
-
- org.bouncycastle.crypto.digests.GeneralDigest
-
- org.bouncycastle.crypto.digests.SHA256Digest
-
- All Implemented Interfaces:
Digest
,EncodableDigest
,ExtendedDigest
,SavableDigest
,Memoable
public class SHA256Digest extends GeneralDigest implements SavableDigest
FIPS 180-2 implementation of SHA-256. block word digest SHA-1 512 32 160 SHA-256 512 32 256 SHA-384 1024 64 384 SHA-512 1024 64 512
-
-
Field Summary
-
Fields inherited from class org.bouncycastle.crypto.digests.GeneralDigest
purpose
-
-
Constructor Summary
Constructors Constructor Description SHA256Digest()
Standard constructorSHA256Digest(byte[] encodedState)
State constructor - create a digest initialised with the state of a previous one.SHA256Digest(CryptoServicePurpose purpose)
Standard constructor, with purposeSHA256Digest(SHA256Digest t)
Copy constructor.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Memoable
copy()
Produce a copy of this object with its configuration and in its current state.protected CryptoServiceProperties
cryptoServiceProperties()
int
doFinal(byte[] out, int outOff)
close the digest, producing the final digest value.java.lang.String
getAlgorithmName()
return the algorithm nameint
getDigestSize()
return the size, in bytes, of the digest produced by this message digest.byte[]
getEncodedState()
Return an encoded byte array for the digest's internal statestatic SavableDigest
newInstance()
static SavableDigest
newInstance(byte[] encoded)
static SavableDigest
newInstance(CryptoServicePurpose purpose)
static SavableDigest
newInstance(Digest digest)
protected void
processBlock()
protected void
processLength(long bitLength)
protected void
processWord(byte[] in, int inOff)
void
reset()
reset the chaining variablesvoid
reset(Memoable other)
Restore a copied object state into this object.-
Methods inherited from class org.bouncycastle.crypto.digests.GeneralDigest
copyIn, finish, getByteLength, populateState, update, update
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.bouncycastle.crypto.ExtendedDigest
getByteLength
-
-
-
-
Constructor Detail
-
SHA256Digest
public SHA256Digest()
Standard constructor
-
SHA256Digest
public SHA256Digest(CryptoServicePurpose purpose)
Standard constructor, with purpose
-
SHA256Digest
public SHA256Digest(SHA256Digest t)
Copy constructor. This will copy the state of the provided message digest.
-
SHA256Digest
public SHA256Digest(byte[] encodedState)
State constructor - create a digest initialised with the state of a previous one.- Parameters:
encodedState
- the encoded state from the originating digest.
-
-
Method Detail
-
newInstance
public static SavableDigest newInstance()
-
newInstance
public static SavableDigest newInstance(CryptoServicePurpose purpose)
-
newInstance
public static SavableDigest newInstance(Digest digest)
-
newInstance
public static SavableDigest newInstance(byte[] encoded)
-
getAlgorithmName
public java.lang.String getAlgorithmName()
Description copied from interface:Digest
return the algorithm name- Specified by:
getAlgorithmName
in interfaceDigest
- Returns:
- the algorithm name
-
getDigestSize
public int getDigestSize()
Description copied from interface:Digest
return the size, in bytes, of the digest produced by this message digest.- Specified by:
getDigestSize
in interfaceDigest
- Returns:
- the size, in bytes, of the digest produced by this message digest.
-
processWord
protected void processWord(byte[] in, int inOff)
- Specified by:
processWord
in classGeneralDigest
-
processLength
protected void processLength(long bitLength)
- Specified by:
processLength
in classGeneralDigest
-
doFinal
public int doFinal(byte[] out, int outOff)
Description copied from interface:Digest
close the digest, producing the final digest value. The doFinal call leaves the digest reset.
-
reset
public void reset()
reset the chaining variables- Specified by:
reset
in interfaceDigest
- Overrides:
reset
in classGeneralDigest
-
processBlock
protected void processBlock()
- Specified by:
processBlock
in classGeneralDigest
-
copy
public Memoable copy()
Description copied from interface:Memoable
Produce a copy of this object with its configuration and in its current state.The returned object may be used simply to store the state, or may be used as a similar object starting from the copied state.
-
reset
public void reset(Memoable other)
Description copied from interface:Memoable
Restore a copied object state into this object.Implementations of this method should try to avoid or minimise memory allocation to perform the reset.
-
getEncodedState
public byte[] getEncodedState()
Description copied from interface:EncodableDigest
Return an encoded byte array for the digest's internal state- Specified by:
getEncodedState
in interfaceEncodableDigest
- Returns:
- an encoding of the digests internal state.
-
cryptoServiceProperties
protected CryptoServiceProperties cryptoServiceProperties()
- Specified by:
cryptoServiceProperties
in classGeneralDigest
-
-