Class ServletContextResource
java.lang.Object
org.springframework.core.io.AbstractResource
org.springframework.core.io.AbstractFileResolvingResource
org.springframework.web.context.support.ServletContextResource
- All Implemented Interfaces:
ContextResource,InputStreamSource,Resource
public class ServletContextResource
extends AbstractFileResolvingResource
implements ContextResource
Resource implementation for
ServletContext resources, interpreting
relative paths within the web application root directory.
Always supports stream access and URL access, but only allows
java.io.File access when the web application archive
is expanded.
- Since:
- 28.12.2003
- Author:
- Juergen Hoeller
- See Also:
-
Constructor Summary
ConstructorsConstructorDescriptionServletContextResource(ServletContext servletContext, String path) Create a newServletContextResourcefor the given path. -
Method Summary
Modifier and TypeMethodDescriptioncreateRelative(String relativePath) This implementation creates a ServletContextResource, applying the given path relative to the path of the underlying file of this resource descriptor.booleanThis implementation compares the underlying ServletContext resource locations.booleanexists()This implementation checksServletContext.getResource.This implementation returns a description that includes the ServletContext resource location.getFile()This implementation resolves "file:" URLs or alternatively delegates toServletContext.getRealPath, throwing a FileNotFoundException if not found or not resolvable.This implementation returns the name of the file that this ServletContext resource refers to.This implementation delegates toServletContext.getResourceAsStream, but throws a FileNotFoundException if no resource found.final StringgetPath()Return the path for this resource.Return the path within the enclosing 'context'.final ServletContextReturn the ServletContext for this resource.getURL()This implementation delegates toServletContext.getResource, but throws a FileNotFoundException if no resource found.inthashCode()This implementation returns the hash code of the underlying ServletContext resource location.booleanisFile()This implementation always returnsfalse.booleanThis implementation delegates toServletContext.getResourceAsStream, which returnsnullin case of a non-readable resource (e.g.Methods inherited from class org.springframework.core.io.AbstractFileResolvingResource
contentLength, customizeConnection, customizeConnection, getFile, getFileForLastModifiedCheck, isFile, lastModified, readableChannelMethods inherited from class org.springframework.core.io.AbstractResource
getURI, isOpen, toStringMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.core.io.Resource
contentLength, getContentAsByteArray, getContentAsString, getURI, isOpen, lastModified, readableChannel
-
Constructor Details
-
ServletContextResource
Create a newServletContextResourcefor the given path.The Servlet spec requires that resource paths start with a slash, even if many containers accept paths without leading slash too. Consequently, the given path will be prepended with a slash if it doesn't already start with one.
- Parameters:
servletContext- the ServletContext to load frompath- the path of the resource
-
-
Method Details
-
getServletContext
Return the ServletContext for this resource. -
getPath
Return the path for this resource. -
exists
public boolean exists()This implementation checksServletContext.getResource.- Specified by:
existsin interfaceResource- Overrides:
existsin classAbstractFileResolvingResource- See Also:
-
isReadable
public boolean isReadable()This implementation delegates toServletContext.getResourceAsStream, which returnsnullin case of a non-readable resource (e.g. a directory).- Specified by:
isReadablein interfaceResource- Overrides:
isReadablein classAbstractFileResolvingResource- See Also:
-
isFile
public boolean isFile()Description copied from class:AbstractResourceThis implementation always returnsfalse.- Specified by:
isFilein interfaceResource- Overrides:
isFilein classAbstractFileResolvingResource- See Also:
-
getInputStream
This implementation delegates toServletContext.getResourceAsStream, but throws a FileNotFoundException if no resource found.- Specified by:
getInputStreamin interfaceInputStreamSource- Returns:
- the input stream for the underlying resource (must not be
null) - Throws:
FileNotFoundException- if the underlying resource does not existIOException- if the content stream could not be opened- See Also:
-
getURL
This implementation delegates toServletContext.getResource, but throws a FileNotFoundException if no resource found.- Specified by:
getURLin interfaceResource- Overrides:
getURLin classAbstractResource- Throws:
IOException- if the resource cannot be resolved as URL, i.e. if the resource is not available as a descriptor- See Also:
-
getFile
This implementation resolves "file:" URLs or alternatively delegates toServletContext.getRealPath, throwing a FileNotFoundException if not found or not resolvable.- Specified by:
getFilein interfaceResource- Overrides:
getFilein classAbstractFileResolvingResource- Throws:
FileNotFoundException- if the resource cannot be resolved as absolute file path, i.e. if the resource is not available in a file systemIOException- in case of general resolution/reading failures- See Also:
-
createRelative
This implementation creates a ServletContextResource, applying the given path relative to the path of the underlying file of this resource descriptor.- Specified by:
createRelativein interfaceResource- Overrides:
createRelativein classAbstractResource- Parameters:
relativePath- the relative path (relative to this resource)- Returns:
- the resource handle for the relative resource
- See Also:
-
getFilename
This implementation returns the name of the file that this ServletContext resource refers to.- Specified by:
getFilenamein interfaceResource- Overrides:
getFilenamein classAbstractResource- See Also:
-
getDescription
This implementation returns a description that includes the ServletContext resource location.- Specified by:
getDescriptionin interfaceResource- See Also:
-
getPathWithinContext
Description copied from interface:ContextResourceReturn the path within the enclosing 'context'.This is typically path relative to a context-specific root directory, e.g. a ServletContext root or a PortletContext root.
- Specified by:
getPathWithinContextin interfaceContextResource
-
equals
This implementation compares the underlying ServletContext resource locations.- Overrides:
equalsin classAbstractResource- See Also:
-
hashCode
public int hashCode()This implementation returns the hash code of the underlying ServletContext resource location.- Overrides:
hashCodein classAbstractResource- See Also:
-