类 PathResourceResolver
- java.lang.Object
- org.springframework.web.reactive.resource.AbstractResourceResolver
- org.springframework.web.reactive.resource.PathResourceResolver
- 所有已实现的接口:
ResourceResolver
public class PathResourceResolver extends AbstractResourceResolver
A simpleResourceResolver
that tries to find a resource under the given locations matching to the request path.This resolver does not delegate to the
ResourceResolverChain
and is expected to be configured at the end in a chain of resolvers.- 从以下版本开始:
- 5.0
- 作者:
- Rossen Stoyanchev
字段概要
从类继承的字段 org.springframework.web.reactive.resource.AbstractResourceResolver
logger
构造器概要
构造器 构造器 说明 PathResourceResolver()
方法概要
所有方法 实例方法 具体方法 修饰符和类型 方法 说明 protected boolean
checkResource(Resource resource, Resource location)
Perform additional checks on a resolved resource beyond checking whether the resources exists and is readable.Resource[]
getAllowedLocations()
protected reactor.core.publisher.Mono<Resource>
getResource(String resourcePath, Resource location)
Find the resource under the given location.protected reactor.core.publisher.Mono<Resource>
resolveResourceInternal(ServerWebExchange exchange, String requestPath, List<? extends Resource> locations, ResourceResolverChain chain)
protected reactor.core.publisher.Mono<String>
resolveUrlPathInternal(String path, List<? extends Resource> locations, ResourceResolverChain chain)
void
setAllowedLocations(Resource... locations)
By default when a Resource is found, the path of the resolved resource is compared to ensure it's under the input location where it was found.从类继承的方法 org.springframework.web.reactive.resource.AbstractResourceResolver
resolveResource, resolveUrlPath
构造器详细资料
PathResourceResolver
public PathResourceResolver()
方法详细资料
setAllowedLocations
public void setAllowedLocations(@Nullable Resource... locations)
By default when a Resource is found, the path of the resolved resource is compared to ensure it's under the input location where it was found. However sometimes that may not be the case, e.g. whenCssLinkResourceTransformer
resolves public URLs of links it contains, the CSS file is the location and the resources being resolved are css files, images, fonts and others located in adjacent or parent directories.This property allows configuring a complete list of locations under which resources must be so that if a resource is not under the location relative to which it was found, this list may be checked as well.
By default
ResourceWebHandler
initializes this property to match its list of locations.- 参数:
locations
- the list of allowed locations
getAllowedLocations
@Nullable public Resource[] getAllowedLocations()
resolveResourceInternal
protected reactor.core.publisher.Mono<Resource> resolveResourceInternal(@Nullable ServerWebExchange exchange, String requestPath, List<? extends Resource> locations, ResourceResolverChain chain)
resolveUrlPathInternal
protected reactor.core.publisher.Mono<String> resolveUrlPathInternal(String path, List<? extends Resource> locations, ResourceResolverChain chain)
getResource
protected reactor.core.publisher.Mono<Resource> getResource(String resourcePath, Resource location)
Find the resource under the given location.The default implementation checks if there is a readable
Resource
for the given path relative to the location.- 参数:
resourcePath
- the path to the resourcelocation
- the location to check- 返回:
- the resource, or empty
Mono
if none found
checkResource
protected boolean checkResource(Resource resource, Resource location) throws IOException
Perform additional checks on a resolved resource beyond checking whether the resources exists and is readable. The default implementation also verifies the resource is either under the location relative to which it was found or is under one of theallowed locations
.- 参数:
resource
- the resource to checklocation
- the location relative to which the resource was found- 返回:
- "true" if resource is in a valid location, "false" otherwise.
- 抛出:
IOException