2003-07-31 19:35:19 +00:00
|
|
|
/* ====================================================================
|
2006-12-22 19:18:16 +00:00
|
|
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
|
contributor license agreements. See the NOTICE file distributed with
|
|
|
|
|
this work for additional information regarding copyright ownership.
|
|
|
|
|
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
|
|
|
(the "License"); you may not use this file except in compliance with
|
|
|
|
|
the License. You may obtain a copy of the License at
|
2004-04-09 13:05:39 +00:00
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
|
limitations under the License.
|
|
|
|
|
==================================================================== */
|
2003-07-31 19:35:19 +00:00
|
|
|
|
|
|
|
|
package org.apache.poi.util;
|
|
|
|
|
|
2007-12-04 12:55:26 +00:00
|
|
|
import java.io.ByteArrayOutputStream;
|
2011-07-04 19:50:01 +00:00
|
|
|
import java.io.Closeable;
|
2003-07-31 19:35:19 +00:00
|
|
|
import java.io.IOException;
|
|
|
|
|
import java.io.InputStream;
|
2008-07-29 23:03:25 +00:00
|
|
|
import java.io.OutputStream;
|
2010-12-18 10:18:43 +00:00
|
|
|
import java.nio.ByteBuffer;
|
|
|
|
|
import java.nio.channels.ReadableByteChannel;
|
2011-06-01 12:07:16 +00:00
|
|
|
import java.util.zip.CRC32;
|
|
|
|
|
import java.util.zip.Checksum;
|
2003-07-31 19:35:19 +00:00
|
|
|
|
2009-08-18 16:50:24 +00:00
|
|
|
public final class IOUtils {
|
2011-07-04 19:50:01 +00:00
|
|
|
|
|
|
|
|
private static final POILogger logger = POILogFactory
|
|
|
|
|
.getLogger( IOUtils.class );
|
|
|
|
|
|
2009-08-18 16:50:24 +00:00
|
|
|
private IOUtils() {
|
|
|
|
|
// no instances of this class
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Reads all the data from the input stream, and returns the bytes read.
|
|
|
|
|
*/
|
|
|
|
|
public static byte[] toByteArray(InputStream stream) throws IOException {
|
|
|
|
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
|
|
|
|
|
|
|
|
|
byte[] buffer = new byte[4096];
|
|
|
|
|
int read = 0;
|
|
|
|
|
while (read != -1) {
|
|
|
|
|
read = stream.read(buffer);
|
|
|
|
|
if (read > 0) {
|
|
|
|
|
baos.write(buffer, 0, read);
|
|
|
|
|
}
|
|
|
|
|
}
|
2003-07-31 19:35:19 +00:00
|
|
|
|
2009-08-18 16:50:24 +00:00
|
|
|
return baos.toByteArray();
|
|
|
|
|
}
|
2007-12-04 12:55:26 +00:00
|
|
|
|
2010-12-19 08:05:44 +00:00
|
|
|
/**
|
|
|
|
|
* Returns an array (that shouldn't be written to!) of the
|
|
|
|
|
* ByteBuffer. Will be of the requested length, or possibly
|
|
|
|
|
* longer if that's easier.
|
|
|
|
|
*/
|
|
|
|
|
public static byte[] toByteArray(ByteBuffer buffer, int length) {
|
|
|
|
|
if(buffer.hasArray() && buffer.arrayOffset() == 0) {
|
|
|
|
|
// The backing array should work out fine for us
|
|
|
|
|
return buffer.array();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
byte[] data = new byte[length];
|
|
|
|
|
buffer.get(data);
|
|
|
|
|
return data;
|
|
|
|
|
}
|
|
|
|
|
|
2009-08-18 16:50:24 +00:00
|
|
|
/**
|
|
|
|
|
* Helper method, just calls <tt>readFully(in, b, 0, b.length)</tt>
|
|
|
|
|
*/
|
|
|
|
|
public static int readFully(InputStream in, byte[] b) throws IOException {
|
|
|
|
|
return readFully(in, b, 0, b.length);
|
|
|
|
|
}
|
2003-07-31 19:35:19 +00:00
|
|
|
|
2009-08-18 16:50:24 +00:00
|
|
|
/**
|
|
|
|
|
* Same as the normal <tt>in.read(b, off, len)</tt>, but tries to ensure
|
|
|
|
|
* that the entire len number of bytes is read.
|
|
|
|
|
* <p>
|
|
|
|
|
* If the end of file is reached before any bytes are read, returns -1. If
|
|
|
|
|
* the end of the file is reached after some bytes are read, returns the
|
|
|
|
|
* number of bytes read. If the end of the file isn't reached before len
|
|
|
|
|
* bytes have been read, will return len bytes.
|
|
|
|
|
*/
|
|
|
|
|
public static int readFully(InputStream in, byte[] b, int off, int len) throws IOException {
|
|
|
|
|
int total = 0;
|
|
|
|
|
while (true) {
|
|
|
|
|
int got = in.read(b, off + total, len - total);
|
|
|
|
|
if (got < 0) {
|
|
|
|
|
return (total == 0) ? -1 : total;
|
|
|
|
|
}
|
|
|
|
|
total += got;
|
|
|
|
|
if (total == len) {
|
|
|
|
|
return total;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2010-12-18 10:18:43 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Same as the normal <tt>channel.read(b)</tt>, but tries to ensure
|
|
|
|
|
* that the entire len number of bytes is read.
|
|
|
|
|
* <p>
|
|
|
|
|
* If the end of file is reached before any bytes are read, returns -1. If
|
|
|
|
|
* the end of the file is reached after some bytes are read, returns the
|
|
|
|
|
* number of bytes read. If the end of the file isn't reached before len
|
|
|
|
|
* bytes have been read, will return len bytes.
|
|
|
|
|
*/
|
|
|
|
|
public static int readFully(ReadableByteChannel channel, ByteBuffer b) throws IOException {
|
|
|
|
|
int total = 0;
|
|
|
|
|
while (true) {
|
2010-12-19 08:53:36 +00:00
|
|
|
int got = channel.read(b);
|
2010-12-18 10:18:43 +00:00
|
|
|
if (got < 0) {
|
|
|
|
|
return (total == 0) ? -1 : total;
|
|
|
|
|
}
|
|
|
|
|
total += got;
|
2011-04-21 15:37:22 +00:00
|
|
|
if (total == b.capacity() || b.position() == b.capacity()) {
|
2010-12-18 10:18:43 +00:00
|
|
|
return total;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2010-12-19 08:05:44 +00:00
|
|
|
|
2009-08-18 16:50:24 +00:00
|
|
|
/**
|
|
|
|
|
* Copies all the data from the given InputStream to the OutputStream. It
|
|
|
|
|
* leaves both streams open, so you will still need to close them once done.
|
|
|
|
|
*/
|
2008-07-29 23:03:25 +00:00
|
|
|
public static void copy(InputStream inp, OutputStream out) throws IOException {
|
|
|
|
|
byte[] buff = new byte[4096];
|
|
|
|
|
int count;
|
2009-08-18 16:50:24 +00:00
|
|
|
while ((count = inp.read(buff)) != -1) {
|
|
|
|
|
if (count > 0) {
|
2008-07-29 23:03:25 +00:00
|
|
|
out.write(buff, 0, count);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2011-06-01 12:07:16 +00:00
|
|
|
|
|
|
|
|
public static long calculateChecksum(byte[] data) {
|
|
|
|
|
Checksum sum = new CRC32();
|
|
|
|
|
sum.update(data, 0, data.length);
|
|
|
|
|
return sum.getValue();
|
|
|
|
|
}
|
2011-07-04 19:50:01 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Quietly (no exceptions) close Closable resource. In case of error it will
|
|
|
|
|
* be printed to {@link IOUtils} class logger.
|
|
|
|
|
*
|
|
|
|
|
* @param closeable
|
|
|
|
|
* resource to close
|
|
|
|
|
*/
|
|
|
|
|
public static void closeQuietly( final Closeable closeable )
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
closeable.close();
|
|
|
|
|
}
|
|
|
|
|
catch ( Exception exc )
|
|
|
|
|
{
|
|
|
|
|
logger.log( POILogger.ERROR, "Unable to close resource: " + exc,
|
|
|
|
|
exc );
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-08-18 16:50:24 +00:00
|
|
|
}
|