diff --git a/spring-boot/src/main/java/org/springframework/boot/context/embedded/undertow/UndertowEmbeddedServletContainerFactory.java b/spring-boot/src/main/java/org/springframework/boot/context/embedded/undertow/UndertowEmbeddedServletContainerFactory.java index 3683c59649d..26b0a827915 100644 --- a/spring-boot/src/main/java/org/springframework/boot/context/embedded/undertow/UndertowEmbeddedServletContainerFactory.java +++ b/spring-boot/src/main/java/org/springframework/boot/context/embedded/undertow/UndertowEmbeddedServletContainerFactory.java @@ -56,7 +56,6 @@ import org.xnio.SslClientAuthMode; import io.undertow.Undertow; import io.undertow.Undertow.Builder; import io.undertow.UndertowMessages; -import io.undertow.server.handlers.resource.ClassPathResourceManager; import io.undertow.server.handlers.resource.FileResourceManager; import io.undertow.server.handlers.resource.Resource; import io.undertow.server.handlers.resource.ResourceChangeListener; @@ -370,10 +369,7 @@ public class UndertowEmbeddedServletContainerFactory if (root != null && root.isFile()) { return new JarResourcemanager(root); } - if (this.resourceLoader != null) { - return new ClassPathResourceManager(this.resourceLoader.getClassLoader(), ""); - } - return new ClassPathResourceManager(getClass().getClassLoader(), ""); + return ResourceManager.EMPTY_RESOURCE_MANAGER; } private void configureErrorPages(DeploymentInfo servletBuilder) { diff --git a/spring-boot/src/test/java/org/springframework/boot/context/embedded/AbstractEmbeddedServletContainerFactoryTests.java b/spring-boot/src/test/java/org/springframework/boot/context/embedded/AbstractEmbeddedServletContainerFactoryTests.java index 6e2e3846c20..72eba6b75e8 100644 --- a/spring-boot/src/test/java/org/springframework/boot/context/embedded/AbstractEmbeddedServletContainerFactoryTests.java +++ b/spring-boot/src/test/java/org/springframework/boot/context/embedded/AbstractEmbeddedServletContainerFactoryTests.java @@ -482,6 +482,17 @@ public abstract class AbstractEmbeddedServletContainerFactoryTests { equalTo("test")); } + @Test + public void cannotReadClassPathFiles() throws Exception { + AbstractEmbeddedServletContainerFactory factory = getFactory(); + this.container = factory + .getEmbeddedServletContainer(exampleServletRegistration()); + this.container.start(); + ClientHttpResponse response = getClientResponse( + getLocalUrl("/org/springframework/boot/SpringApplication.class")); + assertThat(response.getStatusCode(), equalTo(HttpStatus.NOT_FOUND)); + } + private Ssl getSsl(ClientAuth clientAuth, String keyPassword, String keyStore) { return getSsl(clientAuth, keyPassword, keyStore, null); }