public class LoggingByteArrayOutputStream extends ByteArrayOutputStream
Thread-safe byte array output stream that logs what was written to it when the stream is closed.
Use this as a safe way to log a limited amount of content. As content is written to the stream, it is stored as a byte array, up to the maximum number of bytes limit that was set in the constructor. Note that if the maximum limit is set too high, it risks an OutOfMemoryError on low-memory devices. This class also keeps track of the total number of bytes written, regardless of whether they were logged. On #close(), it then logs two records to the specified logger and logging level: the total number of bytes written, and the bounded content logged (assuming charset "UTF-8"). Any control characters are stripped out of the content.
Inheritance
java.lang.Object > java.io.OutputStream > ByteArrayOutputStream > LoggingByteArrayOutputStreamConstructors
LoggingByteArrayOutputStream(Logger logger, Level loggingLevel, int maximumBytesToLog)
public LoggingByteArrayOutputStream(Logger logger, Level loggingLevel, int maximumBytesToLog)
Name | Description |
logger | Logger logger |
loggingLevel | Level logging level |
maximumBytesToLog | int maximum number of bytes to log (may be |
Methods
close()
public synchronized void close()
Type | Description |
IOException |
getBytesWritten()
public final synchronized int getBytesWritten()
Returns the bytes written to the stream (may or may not have been logged).
Type | Description |
int |
getMaximumBytesToLog()
public final int getMaximumBytesToLog()
Returns the maximum number of bytes to log (may be 0
to avoid logging content).
Type | Description |
int |
write(byte[] b, int off, int len)
public synchronized void write(byte[] b, int off, int len)
Name | Description |
b | byte[] |
off | int |
len | int |
write(int b)
public synchronized void write(int b)
Name | Description |
b | int |