Class ZipEntry
- All Implemented Interfaces:
Cloneable
- Direct Known Subclasses:
JarEntry
public class ZipEntry extends Object implements Cloneable
- Since:
- 1.1
Field Summary
Modifier and Type | Field | Description |
---|---|---|
static final int |
CENATT |
Central directory (CEN) header internal file attributes field offset. |
static final int |
CENATX |
Central directory (CEN) header external file attributes field offset. |
static final int |
CENCOM |
Central directory (CEN) header comment length field offset. |
static final int |
CENCRC |
Central directory (CEN) header uncompressed file crc-32 value field offset. |
static final int |
CENDSK |
Central directory (CEN) header disk number start field offset. |
static final int |
CENEXT |
Central directory (CEN) header extra field length field offset. |
static final int |
CENFLG |
Central directory (CEN) header encrypt, decrypt flags field offset. |
static final int |
CENHDR |
Central directory (CEN) header size in bytes (including signature). |
static final int |
CENHOW |
Central directory (CEN) header compression method field offset. |
static final int |
CENLEN |
Central directory (CEN) header uncompressed size field offset. |
static final int |
CENNAM |
Central directory (CEN) header filename length field offset. |
static final int |
CENOFF |
Central directory (CEN) header LOC header offset field offset. |
static final long |
CENSIG |
Central directory (CEN) header signature. |
static final int |
CENSIZ |
Central directory (CEN) header compressed size field offset. |
static final int |
CENTIM |
Central directory (CEN) header modification time field offset. |
static final int |
CENVEM |
Central directory (CEN) header version made by field offset. |
static final int |
CENVER |
Central directory (CEN) header version needed to extract field offset. |
static final int |
DEFLATED |
Compression method for compressed (deflated) entries. |
static final int |
ENDCOM |
End of central directory (END) header zip file comment length field offset. |
static final int |
ENDHDR |
End of central directory (END) header size in bytes (including signature). |
static final int |
ENDOFF |
End of central directory (END) header offset for the first CEN header field offset. |
static final long |
ENDSIG |
End of central directory (END) header signature. |
static final int |
ENDSIZ |
End of central directory (END) header central directory size in bytes field offset. |
static final int |
ENDSUB |
End of central directory (END) header number of entries on this disk field offset. |
static final int |
ENDTOT |
End of central directory (END) header total number of entries field offset. |
static final int |
EXTCRC |
Extra local (EXT) header uncompressed file crc-32 value field offset. |
static final int |
EXTHDR |
Extra local (EXT) header size in bytes (including signature). |
static final int |
EXTLEN |
Extra local (EXT) header uncompressed size field offset. |
static final long |
EXTSIG |
Extra local (EXT) header signature. |
static final int |
EXTSIZ |
Extra local (EXT) header compressed size field offset. |
static final int |
LOCCRC |
Local file (LOC) header uncompressed file crc-32 value field offset. |
static final int |
LOCEXT |
Local file (LOC) header extra field length field offset. |
static final int |
LOCFLG |
Local file (LOC) header general purpose bit flag field offset. |
static final int |
LOCHDR |
Local file (LOC) header size in bytes (including signature). |
static final int |
LOCHOW |
Local file (LOC) header compression method field offset. |
static final int |
LOCLEN |
Local file (LOC) header uncompressed size field offset. |
static final int |
LOCNAM |
Local file (LOC) header filename length field offset. |
static final long |
LOCSIG |
Local file (LOC) header signature. |
static final int |
LOCSIZ |
Local file (LOC) header compressed size field offset. |
static final int |
LOCTIM |
Local file (LOC) header modification time field offset. |
static final int |
LOCVER |
Local file (LOC) header version needed to extract field offset. |
static final int |
STORED |
Compression method for uncompressed entries. |
Constructor Summary
Constructor | Description |
---|---|
ZipEntry |
Creates a new zip entry with the specified name. |
ZipEntry |
Creates a new zip entry with fields taken from the specified zip entry. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
Object |
clone() |
Returns a copy of this entry. |
String |
getComment() |
Returns the comment string for the entry. |
long |
getCompressedSize() |
Returns the size of the compressed entry data. |
long |
getCrc() |
Returns the CRC-32 checksum of the uncompressed entry data. |
FileTime |
getCreationTime() |
Returns the creation time of the entry. |
byte[] |
getExtra() |
Returns the extra field data for the entry. |
FileTime |
getLastAccessTime() |
Returns the last access time of the entry. |
FileTime |
getLastModifiedTime() |
Returns the last modification time of the entry. |
int |
getMethod() |
Returns the compression method of the entry. |
String |
getName() |
Returns the name of the entry. |
long |
getSize() |
Returns the uncompressed size of the entry data. |
long |
getTime() |
Returns the last modification time of the entry. |
LocalDateTime |
getTimeLocal() |
Returns the last modification time of the entry in local date-time. |
int |
hashCode() |
Returns the hash code value for this entry. |
boolean |
isDirectory() |
Returns true if this is a directory entry. |
void |
setComment |
Sets the optional comment string for the entry. |
void |
setCompressedSize |
Sets the size of the compressed entry data. |
void |
setCrc |
Sets the CRC-32 checksum of the uncompressed entry data. |
ZipEntry |
setCreationTime |
Sets the creation time of the entry. |
void |
setExtra |
Sets the optional extra field data for the entry. |
ZipEntry |
setLastAccessTime |
Sets the last access time of the entry. |
ZipEntry |
setLastModifiedTime |
Sets the last modification time of the entry. |
void |
setMethod |
Sets the compression method for the entry. |
void |
setSize |
Sets the uncompressed size of the entry data. |
void |
setTime |
Sets the last modification time of the entry. |
void |
setTimeLocal |
Sets the last modification time of the entry in local date-time. |
String |
toString() |
Returns a string representation of the ZIP entry. |
Field Details
STORED
public static final int STORED
- See Also:
DEFLATED
public static final int DEFLATED
- See Also:
LOCSIG
static final long LOCSIG
- See Also:
EXTSIG
static final long EXTSIG
- See Also:
CENSIG
static final long CENSIG
- See Also:
ENDSIG
static final long ENDSIG
- See Also:
LOCHDR
static final int LOCHDR
- See Also:
EXTHDR
static final int EXTHDR
- See Also:
CENHDR
static final int CENHDR
- See Also:
ENDHDR
static final int ENDHDR
- See Also:
LOCVER
static final int LOCVER
- See Also:
LOCFLG
static final int LOCFLG
- See Also:
LOCHOW
static final int LOCHOW
- See Also:
LOCTIM
static final int LOCTIM
- See Also:
LOCCRC
static final int LOCCRC
- See Also:
LOCSIZ
static final int LOCSIZ
- See Also:
LOCLEN
static final int LOCLEN
- See Also:
LOCNAM
static final int LOCNAM
- See Also:
LOCEXT
static final int LOCEXT
- See Also:
EXTCRC
static final int EXTCRC
- See Also:
EXTSIZ
static final int EXTSIZ
- See Also:
EXTLEN
static final int EXTLEN
- See Also:
CENVEM
static final int CENVEM
- See Also:
CENVER
static final int CENVER
- See Also:
CENFLG
static final int CENFLG
- See Also:
CENHOW
static final int CENHOW
- See Also:
CENTIM
static final int CENTIM
- See Also:
CENCRC
static final int CENCRC
- See Also:
CENSIZ
static final int CENSIZ
- See Also:
CENLEN
static final int CENLEN
- See Also:
CENNAM
static final int CENNAM
- See Also:
CENEXT
static final int CENEXT
- See Also:
CENCOM
static final int CENCOM
- See Also:
CENDSK
static final int CENDSK
- See Also:
CENATT
static final int CENATT
- See Also:
CENATX
static final int CENATX
- See Also:
CENOFF
static final int CENOFF
- See Also:
ENDSUB
static final int ENDSUB
- See Also:
ENDTOT
static final int ENDTOT
- See Also:
ENDSIZ
static final int ENDSIZ
- See Also:
ENDOFF
static final int ENDOFF
- See Also:
ENDCOM
static final int ENDCOM
- See Also:
Constructor Details
ZipEntry
public ZipEntry(String name)
- Parameters:
-
name
- The entry name - Throws:
-
NullPointerException
- if the entry name is null -
IllegalArgumentException
- if the entry name is longer than 0xFFFF bytes
ZipEntry
public ZipEntry(ZipEntry e)
- Parameters:
-
e
- A zip Entry object - Throws:
-
NullPointerException
- if the entry object is null
Method Details
getName
public String getName()
- Returns:
- the name of the entry
setTime
public void setTime(long 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 fields
of the zip file entry and encoded in standard MS-DOS date and time format
. The default TimeZone
is 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
public long getTime()
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 fields
of the zip file entry. The default TimeZone
is 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:
setTimeLocal
public void setTimeLocal(LocalDateTime 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 fields
of the zip file entry and encoded in standard MS-DOS date and time format
. If the date-time set is out of the range of the standard
MS-DOS date and time format
, the time will also be stored into zip file entry's extended timestamp fields in optional
extra data
in UTC time. The system default TimeZone
is used to convert the local date-time to UTC time.
LocalDateTime
uses 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
public LocalDateTime getTimeLocal()
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 data
if the extended timestamp fields are present. Otherwise, the last modification time is read from entry's standard MS-DOS formatted date and time fields
.
The system default TimeZone
is 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:
setLastModifiedTime
public ZipEntry setLastModifiedTime(FileTime time)
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 fields
in standard
MS-DOS date and time format
), and the extended timestamp fields in optional extra data
in UTC time.
- Parameters:
-
time
- The last modification time of the entry - Returns:
- This zip entry
- Throws:
-
NullPointerException
- if thetime
is null - Since:
- 1.8
- See Also:
getLastModifiedTime
public FileTime getLastModifiedTime()
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 data
if the extended timestamp fields are present. Otherwise the last modification time is read from the entry's date and time fields
, the default TimeZone
is 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:
setLastAccessTime
public ZipEntry setLastAccessTime(FileTime time)
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 thetime
is null - Since:
- 1.8
- See Also:
getLastAccessTime
public FileTime getLastAccessTime()
The last access time is from the extended timestamp fields of entry's optional extra data
when 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:
setCreationTime
public ZipEntry setCreationTime(FileTime time)
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 thetime
is null - Since:
- 1.8
- See Also:
getCreationTime
public FileTime getCreationTime()
The creation time is from the extended timestamp fields of entry's optional extra data
when 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:
setSize
public void setSize(long size)
- 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
public long getSize()
- Returns:
- the uncompressed size of the entry data, or -1 if not known
- See Also:
getCompressedSize
public long getCompressedSize()
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
public void setCompressedSize(long csize)
- Parameters:
-
csize
- the compressed size to set - See Also:
setCrc
public void setCrc(long crc)
- 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
public long getCrc()
- Returns:
- the CRC-32 checksum of the uncompressed entry data, or -1 if not known
- See Also:
setMethod
public void setMethod(int method)
- Parameters:
-
method
- the compression method, either STORED or DEFLATED - Throws:
-
IllegalArgumentException
- if the specified compression method is invalid - See Also:
getMethod
public int getMethod()
- Returns:
- the compression method of the entry, or -1 if not specified
- See Also:
setExtra
public void setExtra(byte[] extra)
Invoking this method may change this entry's last modification time, last access time and creation time, if the extra
field data includes the extensible timestamp fields, such as NTFS tag
0x0001
or Info-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
public byte[] getExtra()
- Returns:
- the extra field data for the entry, or null if none
- See Also:
setComment
public void setComment(String comment)
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
public String getComment()
- Returns:
- the comment string for the entry, or null if none
- See Also:
isDirectory
public boolean isDirectory()
- Returns:
- true if this is a directory entry
toString
public String toString()
hashCode
public int hashCode()
clone
public Object clone()
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/zip/ZipEntry.html