Class ResourceWebHandler
- All Implemented Interfaces:
- InitializingBean,- WebHandler
HttpRequestHandler that serves static resources in an optimized way
 according to the guidelines of Page Speed, YSlow, etc.
 The "locations" property takes a list of Spring
 Resource locations from which static resources are allowed to
 be served by this handler. Resources could be served from a classpath location,
 for example, "classpath:/META-INF/public-web-resources/", allowing convenient packaging
 and serving of resources such as .js, .css, and others in jar files.
 
This request handler may also be configured with a
 resourcesResolver and
 resourceTransformer chains to support
 arbitrary resolution and transformation of resources being served. By default
 a PathResourceResolver simply finds resources based on the configured
 "locations". An application can configure additional resolvers and
 transformers such as the VersionResourceResolver which can resolve
 and prepare URLs for resources with a version in the URL.
 
This handler also properly evaluates the Last-Modified header (if
 present) so that a 304 status code will be returned as appropriate,
 avoiding unnecessary overhead for resources that are already cached by the
 client.
- Since:
- 5.0
- Author:
- Rossen Stoyanchev, Brian Clozel, Juergen Hoeller
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.Return theCacheControlinstance to build the Cache-Control HTTP response header.Return the HTTP ETag generator function to be used when serving resources.Return theListofResourcepaths to use as sources for serving static resources.Return the configured location values.Return theconfiguredmedia type mappings.protected reactor.core.publisher.Mono<Resource> getResource(ServerWebExchange exchange) Return the configured resource message writer.Return the list of configured resource resolvers.Return the list of configured resource transformers.reactor.core.publisher.Mono<Void> handle(ServerWebExchange exchange) Processes a resource request.protected voidLook for aPathResourceResolveramong the configured resource resolvers and set itsallowedLocationsproperty (if empty) to match thelocationsconfigured on this class.protected booleanisInvalidPath(String path) Invoked afterResourceHandlerUtils.isInvalidPath(String)to allow subclasses to perform further validation.booleanReturn whether to optimize the specified locations through an existence check on startup, filtering non-existing directories upfront so that they do not have to be checked on every resource access.booleanReturn whether theResource.lastModified()information is used to drive HTTP responses when serving static resources.protected StringprocessPath(String path) Process the given resource path.voidsetCacheControl(@Nullable CacheControl cacheControl) Set theCacheControlinstance to build the Cache-Control HTTP response header.voidsetEtagGenerator(@Nullable Function<Resource, String> etagGenerator) Configure a generator function that will be used to create the ETag information, given aResourcethat is about to be written to the response.protected voidsetHeaders(ServerWebExchange exchange, Resource resource, @Nullable MediaType mediaType) Set headers on the response.voidsetLocations(@Nullable List<Resource> locations) Set theListofResourcepaths to use as sources for serving static resources.voidsetLocationValues(List<String> locationValues) Accepts a list of String-based location values to be resolved intoResourcelocations.voidsetMediaTypes(Map<String, MediaType> mediaTypes) Add mappings between file extensions extracted from the filename of staticResources and the media types to use for the response.voidsetOptimizeLocations(boolean optimizeLocations) Set whether to optimize the specified locations through an existence check on startup, filtering non-existing directories upfront so that they do not have to be checked on every resource access.voidsetResourceHttpMessageWriter(@Nullable ResourceHttpMessageWriter httpMessageWriter) Configure theResourceHttpMessageWriterto use.voidsetResourceLoader(ResourceLoader resourceLoader) Provide the ResourceLoader to loadlocation valueswith.voidsetResourceResolvers(@Nullable List<ResourceResolver> resourceResolvers) Configure the list ofResourceResolversto use.voidsetResourceTransformers(@Nullable List<ResourceTransformer> resourceTransformers) Configure the list ofResourceTransformersto use.voidsetUseLastModified(boolean useLastModified) Set whether we should look at theResource.lastModified()when serving resources and use this information to drive"Last-Modified"HTTP response headers.toString()
- 
Constructor Details- 
ResourceWebHandlerpublic ResourceWebHandler()
 
- 
- 
Method Details- 
setResourceLoaderProvide the ResourceLoader to loadlocation valueswith.- Since:
- 5.1
 
- 
setLocationValues
- 
getLocationValues
- 
setLocations
- 
getLocationsReturn theListofResourcepaths to use as sources for serving static resources.Note that if locationValuesare provided, instead of loaded Resource-based locations, this method will return empty until after initialization viaafterPropertiesSet().Note: The list of locations may be filtered to exclude those that don't actually exist and therefore the list returned from this method may be a subset of all given locations. See setOptimizeLocations(boolean).- See Also:
 
- 
setResourceResolversConfigure the list ofResourceResolversto use.By default PathResourceResolveris configured. If using this property, it is recommended to addPathResourceResolveras the last resolver.
- 
getResourceResolversReturn the list of configured resource resolvers.
- 
setResourceTransformersConfigure the list ofResourceTransformersto use.By default no transformers are configured for use. 
- 
getResourceTransformersReturn the list of configured resource transformers.
- 
setResourceHttpMessageWriterConfigure theResourceHttpMessageWriterto use.By default a ResourceHttpMessageWriterwill be configured.
- 
getResourceHttpMessageWriterReturn the configured resource message writer.
- 
setCacheControlSet theCacheControlinstance to build the Cache-Control HTTP response header.
- 
getCacheControlReturn theCacheControlinstance to build the Cache-Control HTTP response header.
- 
setUseLastModifiedpublic void setUseLastModified(boolean useLastModified) Set whether we should look at theResource.lastModified()when serving resources and use this information to drive"Last-Modified"HTTP response headers.This option is enabled by default and should be turned off if the metadata of the static files should be ignored. - Since:
- 5.3
 
- 
isUseLastModifiedpublic boolean isUseLastModified()Return whether theResource.lastModified()information is used to drive HTTP responses when serving static resources.- Since:
- 5.3
 
- 
setEtagGeneratorConfigure a generator function that will be used to create the ETag information, given aResourcethat is about to be written to the response.This function should return a String that will be used as an argument in ServerWebExchange.checkNotModified(String), ornullif no value can be generated for the given resource.- Parameters:
- etagGenerator- the HTTP ETag generator function to use.
- Since:
- 6.1
 
- 
getEtagGenerator
- 
setOptimizeLocationspublic void setOptimizeLocations(boolean optimizeLocations) Set whether to optimize the specified locations through an existence check on startup, filtering non-existing directories upfront so that they do not have to be checked on every resource access.The default is false, for defensiveness against zip files without directory entries which are unable to expose the existence of a directory upfront. Switch this flag totruefor optimized access in case of a consistent jar layout with directory entries.- Since:
- 5.3.13
 
- 
isOptimizeLocationspublic boolean isOptimizeLocations()Return whether to optimize the specified locations through an existence check on startup, filtering non-existing directories upfront so that they do not have to be checked on every resource access.- Since:
- 5.3.13
 
- 
setMediaTypesAdd mappings between file extensions extracted from the filename of staticResources and the media types to use for the response.Use of this method is typically not necessary since mappings can be also determined via MediaTypeFactory.getMediaType(Resource).- Parameters:
- mediaTypes- media type mappings
- Since:
- 5.3.2
 
- 
getMediaTypesReturn theconfiguredmedia type mappings.- Since:
- 5.3.2
 
- 
afterPropertiesSetDescription copied from interface:InitializingBeanInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.This method allows the bean instance to perform validation of its overall configuration and final initialization when all bean properties have been set. - Specified by:
- afterPropertiesSetin interface- InitializingBean
- Throws:
- Exception- in the event of misconfiguration (such as failure to set an essential property) or if initialization fails for any other reason
 
- 
initAllowedLocationsprotected void initAllowedLocations()Look for aPathResourceResolveramong the configured resource resolvers and set itsallowedLocationsproperty (if empty) to match thelocationsconfigured on this class.
- 
handleProcesses a resource request.Checks for the existence of the requested resource in the configured list of locations. If the resource does not exist, a 404response will be returned to the client. If the resource exists, the request will be checked for the presence of theLast-Modifiedheader, and its value will be compared against the last-modified timestamp of the given resource, returning a304status code if theLast-Modifiedvalue is greater. If the resource is newer than theLast-Modifiedvalue, or the header is not present, the content resource of the resource will be written to the response with caching headers set to expire one year in the future.- Specified by:
- handlein interface- WebHandler
- Parameters:
- exchange- the current server exchange
- Returns:
- Mono<Void>to indicate when request handling is complete
 
- 
getResource
- 
processPathProcess the given resource path.By default, this method delegates to ResourceHandlerUtils.normalizeInputPath(java.lang.String).
- 
isInvalidPathInvoked afterResourceHandlerUtils.isInvalidPath(String)to allow subclasses to perform further validation.By default, this method does not perform any validations. 
- 
setHeadersprotected void setHeaders(ServerWebExchange exchange, Resource resource, @Nullable MediaType mediaType) throws IOException Set headers on the response. Called for both GET and HEAD requests.- Parameters:
- exchange- current exchange
- resource- the identified resource (never- null)
- mediaType- the resource's media type (never- null)
- Throws:
- IOException
 
- 
toString
 
-