Package org.springframework.core.io
Class AbstractFileResolvingResource
java.lang.Object
org.springframework.core.io.AbstractResource
org.springframework.core.io.AbstractFileResolvingResource
- All Implemented Interfaces:
InputStreamSource
,Resource
- Direct Known Subclasses:
ClassPathResource
,ServletContextResource
,UrlResource
Abstract base class for resources which resolve URLs into File references,
such as
UrlResource
or ClassPathResource
.
Detects the "file" protocol as well as the JBoss "vfs" protocol in URLs, resolving file system references accordingly.
- Since:
- 3.0
- Author:
- Juergen Hoeller
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionlong
This method reads the entire InputStream to determine the content length.protected void
Customize the givenHttpURLConnection
before fetching the resource.protected void
Customize the givenURLConnection
before fetching the resource.boolean
exists()
This implementation checks whether a File can be opened, falling back to whether an InputStream can be opened.getFile()
This implementation returns a File reference for the underlying class path resource, provided that it refers to a file in the file system.protected File
This implementation returns a File reference for the given URI-identified resource, provided that it refers to a file in the file system.protected File
This implementation determines the underlying File (or jar file, in case of a resource in a jar/zip).boolean
isFile()
This implementation always returnsfalse
.protected boolean
Determine whether the givenURI
represents a file in a file system.boolean
This implementation always returnstrue
for a resource thatexists
(revised as of 5.1).long
This implementation checks the timestamp of the underlying File, if available.This implementation returns a FileChannel for the given URI-identified resource, provided that it refers to a file in the file system.Methods inherited from class org.springframework.core.io.AbstractResource
createRelative, equals, getFilename, getURI, getURL, hashCode, isOpen, toString
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.springframework.core.io.InputStreamSource
getInputStream
Methods inherited from interface org.springframework.core.io.Resource
getContentAsByteArray, getContentAsString, getDescription
-
Constructor Details
-
AbstractFileResolvingResource
public AbstractFileResolvingResource()
-
-
Method Details
-
exists
public boolean exists()Description copied from class:AbstractResource
This implementation checks whether a File can be opened, falling back to whether an InputStream can be opened.This will cover both directories and content resources.
- Specified by:
exists
in interfaceResource
- Overrides:
exists
in classAbstractResource
-
isReadable
public boolean isReadable()Description copied from class:AbstractResource
This implementation always returnstrue
for a resource thatexists
(revised as of 5.1).- Specified by:
isReadable
in interfaceResource
- Overrides:
isReadable
in classAbstractResource
- See Also:
-
isFile
public boolean isFile()Description copied from class:AbstractResource
This implementation always returnsfalse
.- Specified by:
isFile
in interfaceResource
- Overrides:
isFile
in classAbstractResource
- See Also:
-
getFile
This implementation returns a File reference for the underlying class path resource, provided that it refers to a file in the file system.- Specified by:
getFile
in interfaceResource
- Overrides:
getFile
in classAbstractResource
- 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:
-
getFileForLastModifiedCheck
This implementation determines the underlying File (or jar file, in case of a resource in a jar/zip).- Overrides:
getFileForLastModifiedCheck
in classAbstractResource
- Returns:
- the File to use for timestamp checking (never
null
) - Throws:
FileNotFoundException
- if the resource cannot be resolved as an absolute file path, i.e. is not available in a file systemIOException
- in case of general resolution/reading failures
-
isFile
Determine whether the givenURI
represents a file in a file system.- Since:
- 5.0
- See Also:
-
getFile
This implementation returns a File reference for the given URI-identified resource, provided that it refers to a file in the file system.- Throws:
IOException
- See Also:
-
readableChannel
This implementation returns a FileChannel for the given URI-identified resource, provided that it refers to a file in the file system.- Specified by:
readableChannel
in interfaceResource
- Overrides:
readableChannel
in classAbstractResource
- Returns:
- the byte channel for the underlying resource (must not be
null
) - Throws:
FileNotFoundException
- if the underlying resource doesn't existIOException
- if the content channel could not be opened- Since:
- 5.0
- See Also:
-
contentLength
Description copied from class:AbstractResource
This method reads the entire InputStream to determine the content length.For a custom subclass of
InputStreamResource
, we strongly recommend overriding this method with a more optimal implementation, e.g. checking File length, or possibly simply returning -1 if the stream can only be read once.- Specified by:
contentLength
in interfaceResource
- Overrides:
contentLength
in classAbstractResource
- Throws:
IOException
- if the resource cannot be resolved (in the file system or as some other known physical resource type)- See Also:
-
lastModified
Description copied from class:AbstractResource
This implementation checks the timestamp of the underlying File, if available.- Specified by:
lastModified
in interfaceResource
- Overrides:
lastModified
in classAbstractResource
- Throws:
IOException
- if the resource cannot be resolved (in the file system or as some other known physical resource type)- See Also:
-
customizeConnection
Customize the givenURLConnection
before fetching the resource.Calls
ResourceUtils.useCachesIfNecessary(URLConnection)
and delegates tocustomizeConnection(HttpURLConnection)
if possible. Can be overridden in subclasses.- Parameters:
con
- the URLConnection to customize- Throws:
IOException
- if thrown from URLConnection methods
-
customizeConnection
Customize the givenHttpURLConnection
before fetching the resource.Can be overridden in subclasses for configuring request headers and timeouts.
- Parameters:
con
- the HttpURLConnection to customize- Throws:
IOException
- if thrown from HttpURLConnection methods
-