- All Implemented Interfaces:
Cloneable
- Direct Known Subclasses:
JarEntry
public class ZipEntry extends Object implements Cloneable
- Since:
- 1.1
-
Field Summary
Fields Modifier and Type Field Description static intCENATTstatic intCENATXstatic intCENCOMstatic intCENCRCstatic intCENDSKstatic intCENEXTstatic intCENFLGstatic intCENHDRstatic intCENHOWstatic intCENLENstatic intCENNAMstatic intCENOFFstatic longCENSIGstatic intCENSIZstatic intCENTIMstatic intCENVEMstatic intCENVERstatic intDEFLATEDCompression method for compressed (deflated) entries.static intENDCOMstatic intENDHDRstatic intENDOFFstatic longENDSIGstatic intENDSIZstatic intENDSUBstatic intENDTOTstatic intEXTCRCstatic intEXTHDRstatic intEXTLENstatic longEXTSIGstatic intEXTSIZstatic intLOCCRCstatic intLOCEXTstatic intLOCFLGstatic intLOCHDRstatic intLOCHOWstatic intLOCLENstatic intLOCNAMstatic longLOCSIGstatic intLOCSIZstatic intLOCTIMstatic intLOCVERstatic intSTOREDCompression method for uncompressed entries. -
Constructor Summary
-
Method Summary
Modifier and Type Method Description Objectclone()Returns a copy of this entry.StringgetComment()Returns the comment string for the entry.longgetCompressedSize()Returns the size of the compressed entry data.longgetCrc()Returns the CRC-32 checksum of the uncompressed entry data.FileTimegetCreationTime()Returns the creation time of the entry.byte[]getExtra()Returns the extra field data for the entry.FileTimegetLastAccessTime()Returns the last access time of the entry.FileTimegetLastModifiedTime()Returns the last modification time of the entry.intgetMethod()Returns the compression method of the entry.StringgetName()Returns the name of the entry.longgetSize()Returns the uncompressed size of the entry data.longgetTime()Returns the last modification time of the entry.LocalDateTimegetTimeLocal()Returns the last modification time of the entry in local date-time.inthashCode()Returns the hash code value for this entry.booleanisDirectory()Returns true if this is a directory entry.voidsetComment(String comment)Sets the optional comment string for the entry.voidsetCompressedSize(long csize)Sets the size of the compressed entry data.voidsetCrc(long crc)Sets the CRC-32 checksum of the uncompressed entry data.ZipEntrysetCreationTime(FileTime time)Sets the creation time of the entry.voidsetExtra(byte[] extra)Sets the optional extra field data for the entry.ZipEntrysetLastAccessTime(FileTime time)Sets the last access time of the entry.ZipEntrysetLastModifiedTime(FileTime time)Sets the last modification time of the entry.voidsetMethod(int method)Sets the compression method for the entry.voidsetSize(long size)Sets the uncompressed size of the entry data.voidsetTime(long time)Sets the last modification time of the entry.voidsetTimeLocal(LocalDateTime time)Sets the last modification time of the entry in local date-time.StringtoString()Returns a string representation of the ZIP entry.
-
Field Details
-
STORED
public static final int STOREDCompression method for uncompressed entries.- See Also:
- Constant Field Values
-
DEFLATED
public static final int DEFLATEDCompression method for compressed (deflated) entries.- See Also:
- Constant Field Values
-
LOCSIG
public static final long LOCSIG- See Also:
- Constant Field Values
-
EXTSIG
public static final long EXTSIG- See Also:
- Constant Field Values
-
CENSIG
public static final long CENSIG- See Also:
- Constant Field Values
-
ENDSIG
public static final long ENDSIG- See Also:
- Constant Field Values
-
LOCHDR
public static final int LOCHDR- See Also:
- Constant Field Values
-
EXTHDR
public static final int EXTHDR- See Also:
- Constant Field Values
-
CENHDR
public static final int CENHDR- See Also:
- Constant Field Values
-
ENDHDR
public static final int ENDHDR- See Also:
- Constant Field Values
-
LOCVER
public static final int LOCVER- See Also:
- Constant Field Values
-
LOCFLG
public static final int LOCFLG- See Also:
- Constant Field Values
-
LOCHOW
public static final int LOCHOW- See Also:
- Constant Field Values
-
LOCTIM
public static final int LOCTIM- See Also:
- Constant Field Values
-
LOCCRC
public static final int LOCCRC- See Also:
- Constant Field Values
-
LOCSIZ
public static final int LOCSIZ- See Also:
- Constant Field Values
-
LOCLEN
public static final int LOCLEN- See Also:
- Constant Field Values
-
LOCNAM
public static final int LOCNAM- See Also:
- Constant Field Values
-
LOCEXT
public static final int LOCEXT- See Also:
- Constant Field Values
-
EXTCRC
public static final int EXTCRC- See Also:
- Constant Field Values
-
EXTSIZ
public static final int EXTSIZ- See Also:
- Constant Field Values
-
EXTLEN
public static final int EXTLEN- See Also:
- Constant Field Values
-
CENVEM
public static final int CENVEM- See Also:
- Constant Field Values
-
CENVER
public static final int CENVER- See Also:
- Constant Field Values
-
CENFLG
public static final int CENFLG- See Also:
- Constant Field Values
-
CENHOW
public static final int CENHOW- See Also:
- Constant Field Values
-
CENTIM
public static final int CENTIM- See Also:
- Constant Field Values
-
CENCRC
public static final int CENCRC- See Also:
- Constant Field Values
-
CENSIZ
public static final int CENSIZ- See Also:
- Constant Field Values
-
CENLEN
public static final int CENLEN- See Also:
- Constant Field Values
-
CENNAM
public static final int CENNAM- See Also:
- Constant Field Values
-
CENEXT
public static final int CENEXT- See Also:
- Constant Field Values
-
CENCOM
public static final int CENCOM- See Also:
- Constant Field Values
-
CENDSK
public static final int CENDSK- See Also:
- Constant Field Values
-
CENATT
public static final int CENATT- See Also:
- Constant Field Values
-
CENATX
public static final int CENATX- See Also:
- Constant Field Values
-
CENOFF
public static final int CENOFF- See Also:
- Constant Field Values
-
ENDSUB
public static final int ENDSUB- See Also:
- Constant Field Values
-
ENDTOT
public static final int ENDTOT- See Also:
- Constant Field Values
-
ENDSIZ
public static final int ENDSIZ- See Also:
- Constant Field Values
-
ENDOFF
public static final int ENDOFF- See Also:
- Constant Field Values
-
ENDCOM
public static final int ENDCOM- See Also:
- Constant Field Values
-
-
Constructor Details
-
ZipEntry
Creates a new zip entry with the specified name.- Parameters:
name- The entry name- Throws:
NullPointerException- if the entry name is nullIllegalArgumentException- if the entry name is longer than 0xFFFF bytes
-
ZipEntry
Creates a new zip entry with fields taken from the specified zip entry.- Parameters:
e- A zip Entry object- Throws:
NullPointerException- if the entry object is null
-
-
Method Details
-
getName
Returns the name of the entry.- Returns:
- the name of the entry
-
setTime
public void setTime(long time)Sets the last modification time of the entry.If the entry is output to a ZIP file or ZIP file formatted output stream the last modification time set by this method will be stored into the
date and time fieldsof the zip file entry and encoded in standardMS-DOS date and time format. Thedefault TimeZoneis used to convert the epoch time to the MS-DOS data and time.- Parameters:
time- The last modification time of the entry in milliseconds since the epoch- See Also:
getTime(),getLastModifiedTime()
-
getTime
public long getTime()Returns the last modification time of the entry.If the entry is read from a ZIP file or ZIP file formatted input stream, this is the last modification time from the
date and time fieldsof the zip file entry. Thedefault TimeZoneis used to convert the standard MS-DOS formatted date and time to the epoch time.- Returns:
- The last modification time of the entry in milliseconds since the epoch, or -1 if not specified
- See Also:
setTime(long),setLastModifiedTime(FileTime)
-
setTimeLocal
Sets the last modification time of the entry in local date-time.If the entry is output to a ZIP file or ZIP file formatted output stream the last modification time set by this method will be stored into the
date and time fieldsof the zip file entry and encoded in standardMS-DOS date and time format. If the date-time set is out of the range of the standardMS-DOS date and time format, the time will also be stored into zip file entry's extended timestamp fields inoptional extra datain UTC time. Thesystem default TimeZoneis used to convert the local date-time to UTC time.LocalDateTimeuses a precision of nanoseconds, whereas this class uses a precision of milliseconds. The conversion will truncate any excess precision information as though the amount in nanoseconds was subject to integer division by one million.- Parameters:
time- The last modification time of the entry in local date-time- Since:
- 9
- See Also:
getTimeLocal()
-
getTimeLocal
Returns the last modification time of the entry in local date-time.If the entry is read from a ZIP file or ZIP file formatted input stream, this is the last modification time from the zip file entry's
optional extra dataif the extended timestamp fields are present. Otherwise, the last modification time is read from entry's standard MS-DOS formatteddate and time fields.The
system default TimeZoneis used to convert the UTC time to local date-time.- Returns:
- The last modification time of the entry in local date-time
- Since:
- 9
- See Also:
setTimeLocal(LocalDateTime)
-
setLastModifiedTime
Sets the last modification time of the entry.When output to a ZIP file or ZIP file formatted output stream the last modification time set by this method will be stored into zip file entry's
date and time fieldsinstandard MS-DOS date and time format), and the extended timestamp fields inoptional extra datain UTC time.- Parameters:
time- The last modification time of the entry- Returns:
- This zip entry
- Throws:
NullPointerException- if thetimeis null- Since:
- 1.8
- See Also:
getLastModifiedTime()
-
getLastModifiedTime
Returns the last modification time of the entry.If the entry is read from a ZIP file or ZIP file formatted input stream, this is the last modification time from the zip file entry's
optional extra dataif the extended timestamp fields are present. Otherwise the last modification time is read from the entry'sdate and time fields, thedefault TimeZoneis used to convert the standard MS-DOS formatted date and time to the epoch time.- Returns:
- The last modification time of the entry, null if not specified
- Since:
- 1.8
- See Also:
setLastModifiedTime(FileTime)
-
setLastAccessTime
Sets the last access time of the entry.If set, the last access time will be stored into the extended timestamp fields of entry's
optional extra data, when output to a ZIP file or ZIP file formatted stream.- Parameters:
time- The last access time of the entry- Returns:
- This zip entry
- Throws:
NullPointerException- if thetimeis null- Since:
- 1.8
- See Also:
getLastAccessTime()
-
getLastAccessTime
Returns the last access time of the entry.The last access time is from the extended timestamp fields of entry's
optional extra datawhen read from a ZIP file or ZIP file formatted stream.- Returns:
- The last access time of the entry, null if not specified
- Since:
- 1.8
- See Also:
setLastAccessTime(FileTime)
-
setCreationTime
Sets the creation time of the entry.If set, the creation time will be stored into the extended timestamp fields of entry's
optional extra data, when output to a ZIP file or ZIP file formatted stream.- Parameters:
time- The creation time of the entry- Returns:
- This zip entry
- Throws:
NullPointerException- if thetimeis null- Since:
- 1.8
- See Also:
getCreationTime()
-
getCreationTime
Returns the creation time of the entry.The creation time is from the extended timestamp fields of entry's
optional extra datawhen read from a ZIP file or ZIP file formatted stream.- Returns:
- the creation time of the entry, null if not specified
- Since:
- 1.8
- See Also:
setCreationTime(FileTime)
-
setSize
public void setSize(long size)Sets the uncompressed size of the entry data.- Parameters:
size- the uncompressed size in bytes- Throws:
IllegalArgumentException- if the specified size is less than 0, is greater than 0xFFFFFFFF when ZIP64 format is not supported, or is less than 0 when ZIP64 is supported- See Also:
getSize()
-
getSize
public long getSize()Returns the uncompressed size of the entry data.- Returns:
- the uncompressed size of the entry data, or -1 if not known
- See Also:
setSize(long)
-
getCompressedSize
public long getCompressedSize()Returns the size of the compressed entry data.In the case of a stored entry, the compressed size will be the same as the uncompressed size of the entry.
- Returns:
- the size of the compressed entry data, or -1 if not known
- See Also:
setCompressedSize(long)
-
setCompressedSize
public void setCompressedSize(long csize)Sets the size of the compressed entry data.- Parameters:
csize- the compressed size to set- See Also:
getCompressedSize()
-
setCrc
public void setCrc(long crc)Sets the CRC-32 checksum of the uncompressed entry data.- Parameters:
crc- the CRC-32 value- Throws:
IllegalArgumentException- if the specified CRC-32 value is less than 0 or greater than 0xFFFFFFFF- See Also:
getCrc()
-
getCrc
public long getCrc()Returns the CRC-32 checksum of the uncompressed entry data.- Returns:
- the CRC-32 checksum of the uncompressed entry data, or -1 if not known
- See Also:
setCrc(long)
-
setMethod
public void setMethod(int method)Sets the compression method for the entry.- Parameters:
method- the compression method, either STORED or DEFLATED- Throws:
IllegalArgumentException- if the specified compression method is invalid- See Also:
getMethod()
-
getMethod
public int getMethod()Returns the compression method of the entry.- Returns:
- the compression method of the entry, or -1 if not specified
- See Also:
setMethod(int)
-
setExtra
public void setExtra(byte[] extra)Sets the optional extra field data for the entry.Invoking this method may change this entry's last modification time, last access time and creation time, if the
extrafield data includes the extensible timestamp fields, such asNTFS tag 0x0001orInfo-ZIP Extended Timestamp, as specified in Info-ZIP Application Note 970311.- Parameters:
extra- The extra field data bytes- Throws:
IllegalArgumentException- if the length of the specified extra field data is greater than 0xFFFF bytes- See Also:
getExtra()
-
getExtra
public byte[] getExtra()Returns the extra field data for the entry.- Returns:
- the extra field data for the entry, or null if none
- See Also:
setExtra(byte[])
-
setComment
Sets the optional comment string for the entry.ZIP entry comments have maximum length of 0xffff. If the length of the specified comment string is greater than 0xFFFF bytes after encoding, only the first 0xFFFF bytes are output to the ZIP file entry.
- Parameters:
comment- the comment string- See Also:
getComment()
-
getComment
Returns the comment string for the entry.- Returns:
- the comment string for the entry, or null if none
- See Also:
setComment(String)
-
isDirectory
public boolean isDirectory()Returns true if this is a directory entry. A directory entry is defined to be one whose name ends with a '/'.- Returns:
- true if this is a directory entry
-
toString
Returns a string representation of the ZIP entry. -
hashCode
public int hashCode()Returns the hash code value for this entry.- Overrides:
hashCodein classObject- Returns:
- a hash code value for this object.
- See Also:
Object.equals(java.lang.Object),System.identityHashCode(java.lang.Object)
-
clone
Returns a copy of this entry.
-