| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectjava.io.OutputStream
java.io.FilterOutputStream
org.apache.tools.zip.ZipOutputStream
public class ZipOutputStream
Reimplementation of java.util.zip.ZipOutputStream that does handle the extended
 functionality of this package, especially internal/external file
 attributes and extra fields with different layouts for local file
 data and central directory entries.
 
This class will try to use RandomAccessFile when you know that the output is going to go to a
 file.
If RandomAccessFile cannot be used, this implementation will use
 a Data Descriptor to store size and CRC information for DEFLATED entries, this means, you don't need to
 calculate them yourself.  Unfortunately this is not possible for
 the STORED method, here setting the CRC and
 uncompressed size information is required before putNextEntry can be called.
As of Apache Ant 1.9.0 it transparently supports Zip64
 extensions and thus individual entries and archives larger than 4
 GB or with more than 65536 entries in most cases but explicit
 control is provided via setUseZip64(org.apache.tools.zip.Zip64Mode).  If the stream can not
 user RandomAccessFile and you try to write a ZipEntry of
 unknown size then Zip64 extensions will be disabled by default.
| Nested Class Summary | |
|---|---|
| static class | ZipOutputStream.UnicodeExtraFieldPolicyenum that represents the possible policies for creating Unicode extra fields. | 
| Field Summary | |
|---|---|
| protected  byte[] | bufThis buffer serves as a Deflater. | 
| protected static byte[] | CFH_SIGcentral file header signature | 
| protected static byte[] | DD_SIGdata descriptor signature | 
| protected  java.util.zip.Deflater | defThis Deflater object is used for output. | 
| static int | DEFAULT_COMPRESSIONDefault compression level for deflated entries. | 
| static int | DEFLATEDCompression method for deflated entries. | 
| static int | EFS_FLAGDeprecated. use GeneralPurposeBit.UFT8_NAMES_FLAGinstead | 
| protected static byte[] | EOCD_SIGend of central dir signature | 
| protected static byte[] | LFH_SIGlocal file header signature | 
| static int | STOREDCompression method for stored entries. | 
| Fields inherited from class java.io.FilterOutputStream | 
|---|
| out | 
| Constructor Summary | |
|---|---|
| ZipOutputStream(java.io.File file)Creates a new ZIP OutputStream writing to a File. | |
| ZipOutputStream(java.io.OutputStream out)Creates a new ZIP OutputStream filtering the underlying stream. | |
| Method Summary | |
|---|---|
| protected static long | adjustToLong(int i)Deprecated. use ZipUtil#adjustToLong | 
|  boolean | canWriteEntryData(ZipEntry ae)Whether this stream is able to write the given entry. | 
|  void | close()Closes this output stream and releases any system resources associated with the stream. | 
|  void | closeEntry()Writes all necessary data for this entry. | 
| protected  void | deflate()Writes next block of compressed data to the output stream. | 
|  void | finish() | 
|  void | flush()Flushes this output stream and forces any buffered output bytes to be written out to the stream. | 
| protected  byte[] | getBytes(java.lang.String name)Retrieve the bytes for the given String in the encoding set for this Stream. | 
|  java.lang.String | getEncoding()The encoding to use for filenames and the file comment. | 
|  boolean | isSeekable()This method indicates whether this archive is writing to a seekable stream (i.e., to a random access file). | 
|  void | putNextEntry(ZipEntry archiveEntry) | 
|  void | setComment(java.lang.String comment)Set the file comment. | 
|  void | setCreateUnicodeExtraFields(ZipOutputStream.UnicodeExtraFieldPolicy b)Whether to create Unicode Extra Fields. | 
|  void | setEncoding(java.lang.String encoding)The encoding to use for filenames and the file comment. | 
|  void | setFallbackToUTF8(boolean b)Whether to fall back to UTF and the language encoding flag if the file name cannot be encoded using the specified encoding. | 
|  void | setLevel(int level)Sets the compression level for subsequent entries. | 
|  void | setMethod(int method)Sets the default compression method for subsequent entries. | 
|  void | setUseLanguageEncodingFlag(boolean b)Whether to set the language encoding flag if the file name encoding is UTF-8. | 
|  void | setUseZip64(Zip64Mode mode)Whether Zip64 extensions will be used. | 
| protected static ZipLong | toDosTime(java.util.Date time)Deprecated. use ZipUtil#toDosTime | 
| protected static byte[] | toDosTime(long t)Deprecated. use ZipUtil#toDosTime | 
|  void | write(byte[] b,
      int offset,
      int length)Writes bytes to ZIP entry. | 
| protected  void | writeCentralDirectoryEnd()Writes the "End of central dir record". | 
| protected  void | writeCentralFileHeader(ZipEntry ze)Writes the central file header entry. | 
| protected  void | writeDataDescriptor(ZipEntry ze)Writes the data descriptor entry. | 
| protected  void | writeLocalFileHeader(ZipEntry ze)Writes the local file header entry | 
| protected  void | writeOut(byte[] data)Write bytes to output or random access file. | 
| protected  void | writeOut(byte[] data,
         int offset,
         int length)Write bytes to output or random access file. | 
| protected  void | writeZip64CentralDirectory()Writes the "ZIP64 End of central dir record" and "ZIP64 End of central dir locator". | 
| Methods inherited from class java.io.FilterOutputStream | 
|---|
| write, write | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
public static final int DEFLATED
public static final int DEFAULT_COMPRESSION
public static final int STORED
@Deprecated public static final int EFS_FLAG
GeneralPurposeBit.UFT8_NAMES_FLAG instead
protected final java.util.zip.Deflater def
protected byte[] buf
This attribute is only protected to provide a level of API
 backwards compatibility.  This class used to extend DeflaterOutputStream up to
 Revision 1.13.
protected static final byte[] LFH_SIG
protected static final byte[] DD_SIG
protected static final byte[] CFH_SIG
protected static final byte[] EOCD_SIG
| Constructor Detail | 
|---|
public ZipOutputStream(java.io.OutputStream out)
out - the outputstream to zip
public ZipOutputStream(java.io.File file)
                throws java.io.IOException
file - the file to zip to
java.io.IOException - on error| Method Detail | 
|---|
public boolean isSeekable()
For seekable streams, you don't need to calculate the CRC or
 uncompressed size for STORED entries before
 invoking putNextEntry(org.apache.tools.zip.ZipEntry).
public void setEncoding(java.lang.String encoding)
For a list of possible values see http://java.sun.com/j2se/1.5.0/docs/guide/intl/encoding.doc.html. Defaults to the platform's default character encoding.
encoding - the encoding valuepublic java.lang.String getEncoding()
public void setUseLanguageEncodingFlag(boolean b)
Defaults to true.
public void setCreateUnicodeExtraFields(ZipOutputStream.UnicodeExtraFieldPolicy b)
Defaults to NEVER.
public void setFallbackToUTF8(boolean b)
Defaults to false.
public void setUseZip64(Zip64Mode mode)
When setting the mode to Never,
 putNextEntry(org.apache.tools.zip.ZipEntry), closeEntry(), finish() or close() may throw a Zip64RequiredException if the entry's size or the total size
 of the archive exceeds 4GB or there are more than 65536 entries
 inside the archive.  Any archive created in this mode will be
 readable by implementations that don't support Zip64.
When setting the mode to Always,
 Zip64 extensions will be used for all entries.  Any archive
 created in this mode may be unreadable by implementations that
 don't support Zip64 even if all its contents would be.
When setting the mode to AsNeeded, Zip64 extensions will transparently be used for
 those entries that require them.  This mode can only be used if
 the uncompressed size of the ZipEntry is known
 when calling putNextEntry(org.apache.tools.zip.ZipEntry) or the archive is written
 to a seekable output (i.e. you have used the File-arg constructor) -
 this mode is not valid when the output stream is not seekable
 and the uncompressed size is unknown when putNextEntry(org.apache.tools.zip.ZipEntry) is called.
If no entry inside the resulting archive requires Zip64
 extensions then Never will create the
 smallest archive.  AsNeeded will
 create a slightly bigger archive if the uncompressed size of
 any entry has initially been unknown and create an archive
 identical to Never otherwise.  Always will create an archive that is at
 least 24 bytes per entry bigger than the one Never would create.
Defaults to AsNeeded unless
 putNextEntry(org.apache.tools.zip.ZipEntry) is called with an entry of unknown
 size and data is written to a non-seekable stream - in this
 case the default is Never.
public void finish()
            throws java.io.IOException
Zip64RequiredException - if the archive's size exceeds 4
 GByte or there are more than 65535 entries inside the archive
 and setUseZip64(org.apache.tools.zip.Zip64Mode) is Zip64Mode.Never.
java.io.IOException
public void closeEntry()
                throws java.io.IOException
java.io.IOException - on error
Zip64RequiredException - if the entry's uncompressed or
 compressed size exceeds 4 GByte and setUseZip64(org.apache.tools.zip.Zip64Mode) 
 is Zip64Mode.Never.
public void putNextEntry(ZipEntry archiveEntry)
                  throws java.io.IOException
Zip64RequiredException - if the entry's uncompressed or
 compressed size is known to exceed 4 GByte and setUseZip64(org.apache.tools.zip.Zip64Mode) 
 is Zip64Mode.Never.
java.io.IOExceptionpublic void setComment(java.lang.String comment)
comment - the commentpublic void setLevel(int level)
Default is Deflater.DEFAULT_COMPRESSION.
level - the compression level.
java.lang.IllegalArgumentException - if an invalid compression
 level is specified.public void setMethod(int method)
Default is DEFLATED.
method - an int from java.util.zip.ZipEntrypublic boolean canWriteEntryData(ZipEntry ae)
May return false if it is set up to use encryption or a compression method that hasn't been implemented yet.
public void write(byte[] b,
                  int offset,
                  int length)
           throws java.io.IOException
write in class java.io.FilterOutputStreamb - the byte array to writeoffset - the start position to write fromlength - the number of bytes to write
java.io.IOException - on error
public void close()
           throws java.io.IOException
close in interface java.io.Closeableclose in class java.io.FilterOutputStreamjava.io.IOException - if an I/O error occurs.
Zip64RequiredException - if the archive's size exceeds 4
 GByte or there are more than 65535 entries inside the archive
 and setUseZip64(org.apache.tools.zip.Zip64Mode) is Zip64Mode.Never.
public void flush()
           throws java.io.IOException
flush in interface java.io.Flushableflush in class java.io.FilterOutputStreamjava.io.IOException - if an I/O error occurs.
protected final void deflate()
                      throws java.io.IOException
java.io.IOException - on error
protected void writeLocalFileHeader(ZipEntry ze)
                             throws java.io.IOException
ze - the entry to write
java.io.IOException - on error
protected void writeDataDescriptor(ZipEntry ze)
                            throws java.io.IOException
ze - the entry to write
java.io.IOException - on error
protected void writeCentralFileHeader(ZipEntry ze)
                               throws java.io.IOException
ze - the entry to write
java.io.IOException - on error
Zip64RequiredException - if the archive's size exceeds 4
 GByte and #setUseZip64 is Zip64Mode.Never.
protected void writeCentralDirectoryEnd()
                                 throws java.io.IOException
java.io.IOException - on error
Zip64RequiredException - if the archive's size exceeds 4
 GByte or there are more than 65535 entries inside the archive
 and #setUseZip64 is Zip64Mode.Never.protected static ZipLong toDosTime(java.util.Date time)
time - the Date to convert
ZipLongprotected static byte[] toDosTime(long t)
Stolen from InfoZip's fileio.c
t - number of milliseconds since the epoch
protected byte[] getBytes(java.lang.String name)
                   throws java.util.zip.ZipException
name - the string to get bytes from
java.util.zip.ZipException - on error
protected void writeZip64CentralDirectory()
                                   throws java.io.IOException
java.io.IOException - on error
protected final void writeOut(byte[] data)
                       throws java.io.IOException
data - the byte array to write
java.io.IOException - on error
protected final void writeOut(byte[] data,
                              int offset,
                              int length)
                       throws java.io.IOException
data - the byte array to writeoffset - the start position to write fromlength - the number of bytes to write
java.io.IOException - on errorprotected static long adjustToLong(int i)
i - the value to treat as unsigned int.
| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||