net.shibboleth.ext.spring.resource.PreferFileSystemResourceLoader Maven / Gradle / Ivy
/*
* Licensed to the University Corporation for Advanced Internet Development,
* Inc. (UCAID) under one or more contributor license agreements. See the
* NOTICE file distributed with this work for additional information regarding
* copyright ownership. The UCAID licenses this file to You under the Apache
* License, Version 2.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.shibboleth.ext.spring.resource;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.DefaultResourceLoader;
import org.springframework.core.io.FileSystemResource;
import org.springframework.core.io.Resource;
import org.springframework.core.io.support.ResourcePatternResolver;
import org.springframework.util.Assert;
/**
* An extension of {@link DefaultResourceLoader} that (1) is biased in favor of the filesystem such that bare resource
* paths are assumed to be files rather than classpath resources and (2) supports loading "classpath*:" resources.
*/
public class PreferFileSystemResourceLoader extends DefaultResourceLoader {
/**
* {@inheritDoc}
*
*
* Overrides the standard behavior of path-only resources and treats them as file paths if the path exists. Note
* that this differs from the ordinary Spring contexts that default to file paths because paths are treated as
* absolute if they are in fact absolute.
*
*/
@Override protected Resource getResourceByPath(String path) {
final Resource r = new FileSystemResource(path);
if (r.exists()) {
return r;
}
return super.getResourceByPath(path);
}
/**
* {@inheritDoc}
*
*
* Supports wildcard classpath locations prefixed with {@link ResourcePatternResolver#CLASSPATH_ALL_URL_PREFIX}.
*
*/
@Override public Resource getResource(String location) {
Assert.notNull(location, "Location must not be null");
if (location.startsWith(ResourcePatternResolver.CLASSPATH_ALL_URL_PREFIX)) {
return new ClassPathResource(location.substring(ResourcePatternResolver.CLASSPATH_ALL_URL_PREFIX.length()),
getClassLoader());
}
return super.getResource(location);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy