public class MessageDigestCalculatingInputStream extends ObservableInputStream
ObservableInputStream
. It creates its own ObservableInputStream.Observer
,
which calculates a checksum using a MessageDigest, for example an MD5 sum.
To build an instance, see MessageDigestCalculatingInputStream.Builder
.
See the MessageDigest section in the Java Cryptography Architecture Standard Algorithm Name Documentation for information about standard algorithm names.
Note: Neither ObservableInputStream
, nor MessageDigest
, are thread safe. So is MessageDigestCalculatingInputStream
.
TODO Rename to MessageDigestInputStream in 3.0.
Modifier and Type | Class and Description |
---|---|
static class |
MessageDigestCalculatingInputStream.Builder
Builds a new
MessageDigestCalculatingInputStream instance. |
static class |
MessageDigestCalculatingInputStream.MessageDigestMaintainingObserver
Maintains the message digest.
|
ObservableInputStream.Observer
Constructor and Description |
---|
MessageDigestCalculatingInputStream(java.io.InputStream inputStream)
|
MessageDigestCalculatingInputStream(java.io.InputStream inputStream,
java.security.MessageDigest messageDigest)
|
MessageDigestCalculatingInputStream(java.io.InputStream inputStream,
java.lang.String algorithm)
|
Modifier and Type | Method and Description |
---|---|
static MessageDigestCalculatingInputStream.Builder |
builder()
Constructs a new
MessageDigestCalculatingInputStream.Builder . |
java.security.MessageDigest |
getMessageDigest()
Gets the
MessageDigest , which is being used for generating the checksum. |
add, close, consume, getObservers, read, read, read, remove, removeAllObservers
available, mark, markSupported, reset, skip
@Deprecated public MessageDigestCalculatingInputStream(java.io.InputStream inputStream) throws java.security.NoSuchAlgorithmException
builder()
, MessageDigestCalculatingInputStream.Builder
, and MessageDigestCalculatingInputStream.Builder.get()
.MessageDigest
with the "MD5" algorithm.
The MD5 algorithm is weak and should not be used.
inputStream
- the stream to calculate the message digest forjava.security.NoSuchAlgorithmException
- if no Provider supports a MessageDigestSpi implementation for the specified algorithm.@Deprecated public MessageDigestCalculatingInputStream(java.io.InputStream inputStream, java.security.MessageDigest messageDigest)
builder()
, MessageDigestCalculatingInputStream.Builder
, and MessageDigestCalculatingInputStream.Builder.get()
.MessageDigest
.inputStream
- the stream to calculate the message digest formessageDigest
- the message digest to use@Deprecated public MessageDigestCalculatingInputStream(java.io.InputStream inputStream, java.lang.String algorithm) throws java.security.NoSuchAlgorithmException
builder()
, MessageDigestCalculatingInputStream.Builder
, and MessageDigestCalculatingInputStream.Builder.get()
.MessageDigest
with the given algorithm.inputStream
- the stream to calculate the message digest foralgorithm
- the name of the algorithm requested. See the MessageDigest section in the
Java Cryptography
Architecture Standard Algorithm Name Documentation for information about standard algorithm names.java.security.NoSuchAlgorithmException
- if no Provider supports a MessageDigestSpi implementation for the specified algorithm.public static MessageDigestCalculatingInputStream.Builder builder()
MessageDigestCalculatingInputStream.Builder
.MessageDigestCalculatingInputStream.Builder
.public java.security.MessageDigest getMessageDigest()
MessageDigest
, which is being used for generating the checksum.
Note: The checksum will only reflect the data, which has been read so far. This is probably not, what you expect. Make sure, that the complete
data has been read, if that is what you want. The easiest way to do so is by invoking ObservableInputStream.consume()
.
Copyright © 2010 - 2023 Adobe. All Rights Reserved