Package org.bouncycastle.crypto.signers
Class ISO9796d2Signer
- java.lang.Object
-
- org.bouncycastle.crypto.signers.ISO9796d2Signer
-
- All Implemented Interfaces:
Signer,SignerWithRecovery
public class ISO9796d2Signer extends java.lang.Object implements SignerWithRecovery
ISO9796-2 - mechanism using a hash function with recovery (scheme 1)
-
-
Field Summary
Fields Modifier and Type Field Description static intTRAILER_IMPLICITDeprecated.use ISOTrailersstatic intTRAILER_RIPEMD128Deprecated.use ISOTrailersstatic intTRAILER_RIPEMD160Deprecated.use ISOTrailersstatic intTRAILER_SHA1Deprecated.use ISOTrailersstatic intTRAILER_SHA256Deprecated.use ISOTrailersstatic intTRAILER_SHA384Deprecated.use ISOTrailersstatic intTRAILER_SHA512Deprecated.use ISOTrailersstatic intTRAILER_WHIRLPOOLDeprecated.use ISOTrailers
-
Constructor Summary
Constructors Constructor Description ISO9796d2Signer(AsymmetricBlockCipher cipher, Digest digest)Constructor for a signer with an explicit digest trailer.ISO9796d2Signer(AsymmetricBlockCipher cipher, Digest digest, boolean implicit)Generate a signer with either implicit or explicit trailers for ISO9796-2.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description byte[]generateSignature()generate a signature for the loaded message using the key we were initialised with.byte[]getRecoveredMessage()Return a reference to the recoveredMessage message, either as it was added to a just generated signature, or extracted from a verified one.booleanhasFullMessage()Return true if the full message was recoveredMessage.voidinit(boolean forSigning, CipherParameters param)Initialise the signer for signing or verification.voidreset()reset the internal statevoidupdate(byte b)update the internal digest with the byte bvoidupdate(byte[] in, int off, int len)update the internal digest with the byte array invoidupdateWithRecoveredMessage(byte[] signature)Perform an update with the recovered message before adding any other data.booleanverifySignature(byte[] signature)return true if the signature represents a ISO9796-2 signature for the passed in message.
-
-
-
Field Detail
-
TRAILER_IMPLICIT
public static final int TRAILER_IMPLICIT
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_RIPEMD160
public static final int TRAILER_RIPEMD160
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_RIPEMD128
public static final int TRAILER_RIPEMD128
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_SHA1
public static final int TRAILER_SHA1
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_SHA256
public static final int TRAILER_SHA256
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_SHA512
public static final int TRAILER_SHA512
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_SHA384
public static final int TRAILER_SHA384
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
TRAILER_WHIRLPOOL
public static final int TRAILER_WHIRLPOOL
Deprecated.use ISOTrailers- See Also:
- Constant Field Values
-
-
Constructor Detail
-
ISO9796d2Signer
public ISO9796d2Signer(AsymmetricBlockCipher cipher, Digest digest, boolean implicit)
Generate a signer with either implicit or explicit trailers for ISO9796-2.- Parameters:
cipher- base cipher to use for signature creation/verificationdigest- digest to use.implicit- whether or not the trailer is implicit or gives the hash.
-
ISO9796d2Signer
public ISO9796d2Signer(AsymmetricBlockCipher cipher, Digest digest)
Constructor for a signer with an explicit digest trailer.- Parameters:
cipher- cipher to use.digest- digest to sign with.
-
-
Method Detail
-
init
public void init(boolean forSigning, CipherParameters param)Description copied from interface:SignerInitialise the signer for signing or verification.
-
updateWithRecoveredMessage
public void updateWithRecoveredMessage(byte[] signature) throws InvalidCipherTextExceptionDescription copied from interface:SignerWithRecoveryPerform an update with the recovered message before adding any other data. This must be the first update method called, and calling it will result in the signer assuming that further calls to update will include message content past what is recoverable.- Specified by:
updateWithRecoveredMessagein interfaceSignerWithRecovery- Parameters:
signature- the signature that we are in the process of verifying.- Throws:
InvalidCipherTextException
-
update
public void update(byte b)
update the internal digest with the byte b
-
update
public void update(byte[] in, int off, int len)update the internal digest with the byte array in
-
generateSignature
public byte[] generateSignature() throws CryptoExceptiongenerate a signature for the loaded message using the key we were initialised with.- Specified by:
generateSignaturein interfaceSigner- Throws:
CryptoException
-
verifySignature
public boolean verifySignature(byte[] signature)
return true if the signature represents a ISO9796-2 signature for the passed in message.- Specified by:
verifySignaturein interfaceSigner
-
hasFullMessage
public boolean hasFullMessage()
Return true if the full message was recoveredMessage.- Specified by:
hasFullMessagein interfaceSignerWithRecovery- Returns:
- true on full message recovery, false otherwise.
- See Also:
SignerWithRecovery.hasFullMessage()
-
getRecoveredMessage
public byte[] getRecoveredMessage()
Return a reference to the recoveredMessage message, either as it was added to a just generated signature, or extracted from a verified one.- Specified by:
getRecoveredMessagein interfaceSignerWithRecovery- Returns:
- the full/partial recoveredMessage message.
- See Also:
SignerWithRecovery.getRecoveredMessage()
-
-