Class JarURLConnection
The syntax of a JAR URL is:
jar:<url>!/{entry}
for example:
jar:http://www.foo.com/bar/baz.jar!/COM/foo/Quux.class
Jar URLs should be used to refer to a JAR file or entries in
a JAR file. The example above is a JAR URL which refers to a JAR
entry. If the entry name is omitted, the URL refers to the whole
JAR file:
jar:http://www.foo.com/bar/baz.jar!/
Users should cast the generic URLConnection to a JarURLConnection when they know that the URL they created is a JAR URL, and they need JAR-specific functionality. For example:
URL url = new URL("jar:file:/home/duke/duke.jar!/");
JarURLConnection jarConnection = (JarURLConnection)url.openConnection();
Manifest manifest = jarConnection.getManifest();
JarURLConnection instances can only be used to read from JAR files.
It is not possible to get a OutputStream to modify or write
to the underlying JAR file using this class.
Examples:
- A Jar entry
jar:http://www.foo.com/bar/baz.jar!/COM/foo/Quux.class- A Jar file
jar:http://www.foo.com/bar/baz.jar!/- A Jar directory
jar:http://www.foo.com/bar/baz.jar!/COM/foo/
!/ is referred to as the separator.
When constructing a JAR url via new URL(context, spec),
the following rules apply:
- if there is no context URL and the specification passed to the URL constructor doesn't contain a separator, the URL is considered to refer to a JarFile.
- if there is a context URL, the context URL is assumed to refer to a JAR file or a Jar directory.
- if the specification begins with a '/', the Jar directory is
ignored, and the spec is considered to be at the root of the Jar
file.
Examples:
- context: jar:http://www.foo.com/bar/jar.jar!/, spec:baz/entry.txt
- url:jar:http://www.foo.com/bar/jar.jar!/baz/entry.txt
- context: jar:http://www.foo.com/bar/jar.jar!/baz, spec:entry.txt
- url:jar:http://www.foo.com/bar/jar.jar!/baz/entry.txt
- context: jar:http://www.foo.com/bar/jar.jar!/baz, spec:/entry.txt
- url:jar:http://www.foo.com/bar/jar.jar!/entry.txt
- Since:
- 1.2
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected URLConnectionThe connection to the JAR file URL, if the connection has been initiated.Fields declared in class URLConnection
allowUserInteraction, connected, doInput, doOutput, ifModifiedSince, url, useCachesModifier and TypeFieldDescriptionprotected booleanIftrue, thisURLis being examined in a context in which it makes sense to allow user interactions such as popping up an authentication dialog.protected booleanIffalse, this connection object has not created a communications link to the specified URL.protected booleanThis variable is set by thesetDoInputmethod.protected booleanThis variable is set by thesetDoOutputmethod.protected longSome protocols support skipping the fetching of the object unless the object has been modified more recently than a certain time.protected URLThe URL represents the remote object on the World Wide Web to which this connection is opened.protected booleanIftrue, the protocol is allowed to use caching whenever it can. -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedJarURLConnection(URL url) Creates the new JarURLConnection to the specified URL. -
Method Summary
Modifier and TypeMethodDescriptionReturn the Attributes object for this connection if the URL for it points to a JAR file entry, null otherwise.Returns the Certificate objects for this connection if the URL for it points to a JAR file entry, null otherwise.Return the entry name for this connection.Return the JAR entry object for this connection, if any.abstract JarFileReturn the JAR file for this connection.Returns the URL for the Jar file for this connection.Returns the main Attributes for the JAR file for this connection.Returns the Manifest for this connection, or null if none.Methods declared in class URLConnection
addRequestProperty, connect, getAllowUserInteraction, getConnectTimeout, getContent, getContent, getContentEncoding, getContentLength, getContentLengthLong, getContentType, getDate, getDefaultAllowUserInteraction, getDefaultRequestProperty, getDefaultUseCaches, getDefaultUseCaches, getDoInput, getDoOutput, getExpiration, getFileNameMap, getHeaderField, getHeaderField, getHeaderFieldDate, getHeaderFieldInt, getHeaderFieldKey, getHeaderFieldLong, getHeaderFields, getIfModifiedSince, getInputStream, getLastModified, getOutputStream, getPermission, getReadTimeout, getRequestProperties, getRequestProperty, getURL, getUseCaches, guessContentTypeFromName, guessContentTypeFromStream, setAllowUserInteraction, setConnectTimeout, setContentHandlerFactory, setDefaultAllowUserInteraction, setDefaultRequestProperty, setDefaultUseCaches, setDefaultUseCaches, setDoInput, setDoOutput, setFileNameMap, setIfModifiedSince, setReadTimeout, setRequestProperty, setUseCaches, toStringModifier and TypeMethodDescriptionvoidaddRequestProperty(String key, String value) Adds a general request property specified by a key-value pair.abstract voidconnect()Opens a communications link to the resource referenced by this URL, if such a connection has not already been established.booleanReturns the value of theallowUserInteractionfield for this object.intReturns setting for connect timeout.Retrieves the contents of this URL connection.getContent(Class<?>[] classes) Retrieves the contents of this URL connection.Returns the value of thecontent-encodingheader field.intReturns the value of thecontent-lengthheader field.longReturns the value of thecontent-lengthheader field as a long.Returns the value of thecontent-typeheader field.longgetDate()Returns the value of thedateheader field.static booleanReturns the default value of theallowUserInteractionfield.static StringDeprecated.The instance specific getRequestProperty method should be used after an appropriate instance of URLConnection is obtained.booleanReturns the default value of aURLConnection'suseCachesflag.static booleangetDefaultUseCaches(String protocol) Returns the default value of theuseCachesflag for the given protocol.booleanReturns the value of thisURLConnection'sdoInputflag.booleanReturns the value of thisURLConnection'sdoOutputflag.longReturns the value of theexpiresheader field.static FileNameMapLoads filename map (a mimetable) from a data file.getHeaderField(int n) Returns the value for thenth header field.getHeaderField(String name) Returns the value of the named header field.longgetHeaderFieldDate(String name, long defaultValue) Returns the value of the named field parsed as date.intgetHeaderFieldInt(String name, int defaultValue) Returns the value of the named field parsed as a number.getHeaderFieldKey(int n) Returns the key for thenth header field.longgetHeaderFieldLong(String name, long defaultValue) Returns the value of the named field parsed as a number.Returns an unmodifiable Map of the header fields.longReturns the value of this object'sifModifiedSincefield.Returns an input stream that reads from this open connection.longReturns the value of thelast-modifiedheader field.Returns an output stream that writes to this connection.Deprecated, for removal: This API element is subject to removal in a future version.Permissions can no longer be used for controlling access to resources as the Security Manager is no longer supported.intReturns setting for read timeout. 0 return implies that the option is disabled (i.e., timeout of infinity).Returns an unmodifiable Map of general request properties for this connection.getRequestProperty(String key) Returns the value of the named general request property for this connection.getURL()Returns the value of thisURLConnection'sURLfield.booleanReturns the value of thisURLConnection'suseCachesfield.static StringguessContentTypeFromName(String fname) Tries to determine the content type of an object, based on the specified "file" component of a URL.static StringTries to determine the type of an input stream based on the characters at the beginning of the input stream.voidsetAllowUserInteraction(boolean allowuserinteraction) Set the value of theallowUserInteractionfield of thisURLConnection.voidsetConnectTimeout(int timeout) Sets a specified timeout value, in milliseconds, to be used when opening a communications link to the resource referenced by this URLConnection.static voidSets theContentHandlerFactoryof an application.static voidsetDefaultAllowUserInteraction(boolean defaultallowuserinteraction) Sets the default value of theallowUserInteractionfield for all futureURLConnectionobjects to the specified value.static voidsetDefaultRequestProperty(String key, String value) Deprecated.The instance specific setRequestProperty method should be used after an appropriate instance of URLConnection is obtained.voidsetDefaultUseCaches(boolean defaultusecaches) Sets the default value of theuseCachesfield to the specified value.static voidsetDefaultUseCaches(String protocol, boolean defaultVal) Sets the default value of theuseCachesfield for the named protocol to the given value.voidsetDoInput(boolean doinput) Sets the value of thedoInputfield for thisURLConnectionto the specified value.voidsetDoOutput(boolean dooutput) Sets the value of thedoOutputfield for thisURLConnectionto the specified value.static voidSets the FileNameMap.voidsetIfModifiedSince(long ifmodifiedsince) Sets the value of theifModifiedSincefield of thisURLConnectionto the specified value.voidsetReadTimeout(int timeout) Sets the read timeout to a specified timeout, in milliseconds.voidsetRequestProperty(String key, String value) Sets the general request property.voidsetUseCaches(boolean usecaches) Sets the value of theuseCachesfield of thisURLConnectionto the specified value.toString()Returns aStringrepresentation of this URL connection.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()Creates and returns a copy of this object.booleanIndicates whether some other object is "equal to" this one.protected voidfinalize()Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class<?> getClass()Returns the runtime class of thisObject.inthashCode()Returns a hash code value for this object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.final voidwait()Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final voidwait(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final voidwait(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Field Details
-
jarFileURLConnection
The connection to the JAR file URL, if the connection has been initiated. This should be set by connect.
-
-
Constructor Details
-
JarURLConnection
Creates the new JarURLConnection to the specified URL.- Parameters:
url- the URL- Throws:
MalformedURLException- if no legal protocol could be found in a specification string or the string could not be parsed.
-
-
Method Details
-
getJarFileURL
Returns the URL for the Jar file for this connection.- Returns:
- the URL for the Jar file for this connection.
-
getEntryName
Return the entry name for this connection. This method returns null if the JAR file URL corresponding to this connection points to a JAR file and not a JAR file entry.- Returns:
- the entry name for this connection, if any.
-
getJarFile
Return the JAR file for this connection.- Returns:
- the JAR file for this connection. If the connection is a connection to an entry of a JAR file, the JAR file object is returned
- Throws:
IOException- if an IOException occurs while trying to connect to the JAR file for this connection.- See Also:
-
getManifest
Returns the Manifest for this connection, or null if none.- Returns:
- the manifest object corresponding to the JAR file object for this connection.
- Throws:
IOException- if getting the JAR file for this connection causes an IOException to be thrown.- See Also:
-
getJarEntry
Return the JAR entry object for this connection, if any. This method returns null if the JAR file URL corresponding to this connection points to a JAR file and not a JAR file entry.- Returns:
- the JAR entry object for this connection, or null if the JAR URL for this connection points to a JAR file.
- Throws:
IOException- if getting the JAR file for this connection causes an IOException to be thrown.- See Also:
-
getAttributes
Return the Attributes object for this connection if the URL for it points to a JAR file entry, null otherwise.- Returns:
- the Attributes object for this connection if the URL for it points to a JAR file entry, null otherwise.
- Throws:
IOException- if getting the JAR entry causes an IOException to be thrown.- See Also:
-
getMainAttributes
Returns the main Attributes for the JAR file for this connection.- Returns:
- the main Attributes for the JAR file for this connection.
- Throws:
IOException- if getting the manifest causes an IOException to be thrown.- See Also:
-
getCertificates
Returns the Certificate objects for this connection if the URL for it points to a JAR file entry, null otherwise. This method can only be called once the connection has been completely verified by reading from the input stream until the end of the stream has been reached. Otherwise, this method will returnnull.The returned certificate array comprises all the signer certificates that were used to verify this entry. Each signer certificate is followed by its supporting certificate chain (which may be empty). Each signer certificate and its supporting certificate chain are ordered bottom-to-top (i.e., with the signer certificate first and the (root) certificate authority last).
- API Note:
- The verification process does not include validating or establishing
trust in the code signers. A caller should perform additional checks,
such as using a
CertPathValidatorto validate each signer's certificate chain, and determining whether to trust the entry signed by the signers. - Returns:
- the Certificate objects for this connection if the URL for it points to a JAR file entry, null otherwise.
- Throws:
IOException- if getting the JAR entry causes an IOException to be thrown.- See Also:
-