Class PathResource
- java.lang.Object
- 
- org.eclipse.jetty.util.resource.Resource
- 
- org.eclipse.jetty.util.resource.PathResource
 
 
- 
- All Implemented Interfaces:
- java.io.Closeable,- java.lang.AutoCloseable,- ResourceFactory
 
 public class PathResource extends Resource Java NIO Path equivalent of FileResource.
- 
- 
Field Summary- 
Fields inherited from class org.eclipse.jetty.util.resource.Resource__defaultUseCaches
 
- 
 - 
Constructor SummaryConstructors Constructor Description PathResource(java.io.File file)Construct a new PathResource from a File object.PathResource(java.net.URI uri)Construct a new PathResource from a URI object.PathResource(java.net.URL url)Create a new PathResource from a provided URL object.PathResource(java.nio.file.Path path)Construct a new PathResource from a Path object.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description ResourceaddPath(java.lang.String subPath)Returns the resource contained inside the current resource with the given name.voidclose()Release any temporary resources held by the resource.voidcopyTo(java.io.File destination)Copy the Resource to the new destination file.booleandelete()Deletes the given resourcebooleanequals(java.lang.Object obj)booleanexists()java.net.URIgetAlias()java.nio.file.PathgetAliasPath()The Alias as a Path.java.io.FilegetFile()File representing the given resource.java.io.InputStreamgetInputStream()Input stream to the resourcejava.lang.StringgetName()The name of the resource.java.nio.file.PathgetPath()java.nio.channels.ReadableByteChannelgetReadableByteChannel()Readable ByteChannel for the resource.java.net.URIgetURI()URI representing the resource.java.net.URLgetURL()URL representing the resource.inthashCode()booleanisAlias()booleanisContainedIn(Resource r)booleanisDirectory()booleanisSame(Resource resource)Return true if the passed Resource represents the same resource as the Resource.static booleanisSameName(java.nio.file.Path pathA, java.nio.file.Path pathB)Test if the paths are the same name.longlastModified()Time resource was last modified.longlength()Length of the resource.java.lang.String[]list()list of resource names contained in the given resource.java.nio.channels.SeekableByteChannelnewSeekableByteChannel()booleanrenameTo(Resource dest)Rename the given resourcejava.lang.StringtoString()voidwriteTo(java.io.OutputStream outputStream, long start, long count)- 
Methods inherited from class org.eclipse.jetty.util.resource.Resourceencode, finalize, getAllResources, getAssociate, getDefaultUseCaches, getListHTML, getListHTML, getResource, getWeakETag, getWeakETag, isContainedIn, newClassPathResource, newClassPathResource, newResource, newResource, newResource, newResource, newResource, newResource, newSystemResource, release, setAssociate, setDefaultUseCaches, toURL
 
- 
 
- 
- 
- 
Constructor Detail- 
PathResourcepublic PathResource(java.io.File file) Construct a new PathResource from a File object.An invocation of this convenience constructor of the form. new PathResource(file); behaves in exactly the same way as the expression new PathResource(file.toPath()); - Parameters:
- file- the file to use
 
 - 
PathResourcepublic PathResource(java.nio.file.Path path) Construct a new PathResource from a Path object.- Parameters:
- path- the path to use
 
 - 
PathResourcepublic PathResource(java.net.URI uri) throws java.io.IOExceptionConstruct a new PathResource from a URI object.Must be an absolute URI using the filescheme.- Parameters:
- uri- the URI to build this PathResource from.
- Throws:
- java.io.IOException- if unable to construct the PathResource from the URI.
 
 - 
PathResourcepublic PathResource(java.net.URL url) throws java.io.IOException, java.net.URISyntaxExceptionCreate a new PathResource from a provided URL object.An invocation of this convenience constructor of the form. new PathResource(url); behaves in exactly the same way as the expression new PathResource(url.toURI()); - Parameters:
- url- the url to attempt to create PathResource from
- Throws:
- java.io.IOException- if URL doesn't point to a location that can be transformed to a PathResource
- java.net.URISyntaxException- if the provided URL was malformed
 
 
- 
 - 
Method Detail- 
isSameNamepublic static boolean isSameName(java.nio.file.Path pathA, java.nio.file.Path pathB)Test if the paths are the same name.If the real path is not the same as the absolute path then we know that the real path is the alias for the provided path. For OS's that are case insensitive, this should return the real (on-disk / case correct) version of the path. We have to be careful on Windows and OSX. Assume we have the following scenario: Path a = new File("foo").toPath(); Files.createFile(a); Path b = new File("FOO").toPath();There now exists a file called fooon disk. Using Windows or OSX, with a Path reference ofFOO,Foo,fOO, etc.. means the following| OSX | Windows | Linux -----------------------+---------+------------+--------- Files.exists(a) | True | True | True Files.exists(b) | True | True | False Files.isSameFile(a,b) | True | True | False a.equals(b) | False | True | FalseSee the javadoc for Path.equals() for details about this FileSystem behavior difference We also cannot rely on a.compareTo(b) as this is roughly equivalent in implementation to a.equals(b) 
 - 
isSamepublic boolean isSame(Resource resource) Description copied from class:ResourceReturn true if the passed Resource represents the same resource as the Resource. For many resource types, this is equivalent toObject.equals(Object), however for resources types that support aliasing, this maybe some other check (e.g.Files.isSameFile(Path, Path)).
 - 
addPathpublic Resource addPath(java.lang.String subPath) throws java.io.IOException Description copied from class:ResourceReturns the resource contained inside the current resource with the given name.- Specified by:
- addPathin class- Resource
- Parameters:
- subPath- The path segment to add, which is not encoded. The path may be non canonical, but if so then the resulting Resource will return true from- Resource.isAlias().
- Returns:
- the Resource for the resolved path within this Resource.
- Throws:
- java.io.IOException- if unable to resolve the path
- java.net.MalformedURLException- if the resolution of the path fails because the input path parameter is malformed, or a relative path attempts to access above the root resource.
 
 - 
closepublic void close() Description copied from class:ResourceRelease any temporary resources held by the resource.
 - 
deletepublic boolean delete() throws java.lang.SecurityExceptionDescription copied from class:ResourceDeletes the given resource
 - 
equalspublic boolean equals(java.lang.Object obj) - Overrides:
- equalsin class- java.lang.Object
 
 - 
existspublic boolean exists() 
 - 
getFilepublic java.io.File getFile() throws java.io.IOExceptionDescription copied from class:ResourceFile representing the given resource.
 - 
getPathpublic java.nio.file.Path getPath() - Returns:
- the Pathof the resource
 
 - 
getInputStreampublic java.io.InputStream getInputStream() throws java.io.IOExceptionDescription copied from class:ResourceInput stream to the resource- Specified by:
- getInputStreamin class- Resource
- Returns:
- an input stream to the resource
- Throws:
- java.io.IOException- if unable to open the input stream
 
 - 
getNamepublic java.lang.String getName() Description copied from class:ResourceThe name of the resource.
 - 
getReadableByteChannelpublic java.nio.channels.ReadableByteChannel getReadableByteChannel() throws java.io.IOExceptionDescription copied from class:ResourceReadable ByteChannel for the resource.- Specified by:
- getReadableByteChannelin class- Resource
- Returns:
- an readable bytechannel to the resource or null if one is not available.
- Throws:
- java.io.IOException- if unable to open the readable bytechannel for the resource.
 
 - 
newSeekableByteChannelpublic java.nio.channels.SeekableByteChannel newSeekableByteChannel() throws java.io.IOException- Throws:
- java.io.IOException
 
 - 
getURIpublic java.net.URI getURI() Description copied from class:ResourceURI representing the resource.
 - 
getURLpublic java.net.URL getURL() Description copied from class:ResourceURL representing the resource.
 - 
hashCodepublic int hashCode() - Overrides:
- hashCodein class- java.lang.Object
 
 - 
isContainedInpublic boolean isContainedIn(Resource r) throws java.net.MalformedURLException - Specified by:
- isContainedInin class- Resource
- Throws:
- java.net.MalformedURLException
 
 - 
isDirectorypublic boolean isDirectory() - Specified by:
- isDirectoryin class- Resource
- Returns:
- true if the represented resource is a container/directory. if the resource is not a file, resources ending with "/" are considered directories.
 
 - 
lastModifiedpublic long lastModified() Description copied from class:ResourceTime resource was last modified.- Specified by:
- lastModifiedin class- Resource
- Returns:
- the last modified time as milliseconds since unix epoch
 
 - 
lengthpublic long length() Description copied from class:ResourceLength of the resource.
 - 
isAliaspublic boolean isAlias() 
 - 
getAliasPathpublic java.nio.file.Path getAliasPath() The Alias as a Path.Note: this cannot return the alias as a DIFFERENT path in 100% of situations, due to Java's internal Path/File normalization. - Returns:
- the alias as a path.
 
 - 
getAliaspublic java.net.URI getAlias() 
 - 
listpublic java.lang.String[] list() Description copied from class:Resourcelist of resource names contained in the given resource. Ordering is unspecified, so callers may wish to sort the return value to ensure deterministic behavior.
 - 
renameTopublic boolean renameTo(Resource dest) throws java.lang.SecurityException Description copied from class:ResourceRename the given resource
 - 
copyTopublic void copyTo(java.io.File destination) throws java.io.IOExceptionDescription copied from class:ResourceCopy the Resource to the new destination file.Will not replace existing destination file. 
 - 
writeTopublic void writeTo(java.io.OutputStream outputStream, long start, long count) throws java.io.IOException
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 
- 
 
-