我正在使用Spring Boot,并尝试在部署时使我的静态资源(CSS,JS,Fonts)可用。源代码可供您查看或克隆https://github.com/joecracko/StaticResourceError。
现在我的CSS,JS和Font文件对我已部署的网站不可见。
这是我的项目目录结构:
以下是已编译JAR的根目录:我向您保证文件存在于各自的文件夹中。
以下是我看到的网络错误:
以下是Chrome工具提供的资源。请注意,bar.css在此处显示为空。您可以查看我的源代码,看它是不是空的。
这是我的homepage.html
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>Insert title here</title>
<!-- Main Styles -->
<link rel="stylesheet" href="/css/bar.css" />
<script src="/js/foo.js"></script>
</head>
<body>
<div>Welcome to Foo!</div>
</body>
</html>
这是我的Web App Initializer (FooWebAppInitializer.java)
public class FooWebAppInitializer implements WebApplicationInitializer {
@Override
public void onStartup(ServletContext container) {
AnnotationConfigWebApplicationContext rootContext = new AnnotationConfigWebApplicationContext();
rootContext.register(ServletConfig.class);
// Manage the lifecycle of the root application context
container.addListener(new ContextLoaderListener(rootContext));
//Spring Security
container.addFilter("springSecurityFilterChain", new DelegatingFilterProxy("springSecurityFilterChain"))
.addMappingForUrlPatterns(null, false, "/*");
// Register and map the dispatcher servlet
ServletRegistration.Dynamic dispatcher = container.addServlet("dispatcherServlet", new DispatcherServlet(rootContext));
dispatcher.setLoadOnStartup(1);
dispatcher.addMapping("/*");
dispatcher.addMapping("*.css");
dispatcher.addMapping("*.eot");
dispatcher.addMapping("*.svg");
dispatcher.addMapping("*.ttf");
dispatcher.addMapping("*.woff");
dispatcher.addMapping("*.map");
dispatcher.addMapping("*.js");
dispatcher.addMapping("*.ico");
}
}
这是我的Servlet配置(ServletConfig.java)
@Configuration
@EnableWebMvc
@ComponentScan({"com.foo"})
public class ServletConfig extends WebMvcAutoConfiguration{
@Bean
MultipartResolver multipartResolver() {
return new StandardServletMultipartResolver();
}
@Bean
public ResourceBundleMessageSource messageSource() {
ResourceBundleMessageSource source = new ResourceBundleMessageSource();
source.setBasename("messages");
return source;
}
}
对于踢,My Spring Security Config (WebSecurityConfig.java)
@Configuration
@EnableWebMvcSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.authorizeRequests()
.anyRequest().permitAll();
}
@Override
public void configure(WebSecurity web) throws Exception {
web.ignoring().antMatchers("/resources/**"); // #3
}
}
答案 0 :(得分:16)
将静态资源放在目录下:
/src/main/resources/static
您也可以使用public
或resources
代替static
作为文件夹名称。
解释:您的构建工具(Maven或Gradle)将复制应用程序类路径中/src/main/resources/
的所有内容,并在{{3 }},类路径中名为/static
(或/public
或/resources
}的目录中的所有内容都将作为静态内容提供。
这个目录也可以,但不鼓励:
/src/main/webapp/
如果您的应用程序是,请不要使用src / main / webapp目录 打包成一个罐子。虽然这个目录是一个通用标准,但它 只会与战争包装一起使用,它将被默默地忽略 如果你生成一个jar,大多数构建工具。
答案 1 :(得分:1)
有两件事需要考虑(Spring Boot v1.5.2.RELEASE) - 1)检查@EnableWebMvc注释的所有Controller类,如果有则删除它 2)检查使用了注释的Controller类 - @RestController或@Controller。不要在一个类中混合Rest API和MVC行为。对于MVC,使用@Controller和REST API使用@RestController
做上述2件事解决了我的问题。现在我的spring boot正在加载静态资源,没有任何问题。 @Controller =&gt; load index.html =&gt;加载静态文件。
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Hello</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link rel="stylesheet/less" th:href="@{/webapp/assets/theme.siberia.less}"/>
<!-- The app's logic -->
<script type="text/javascript" data-main="/webapp/app" th:src="@{/webapp/libs/require.js}"></script>
<script type="text/javascript">
require.config({
paths: { text:"/webapp/libs/text" }
});
</script>
<!-- Development only -->
<script type="text/javascript" th:src="@{/webapp/libs/less.min.js}"></script>
</head>
<body>
</body>
</html>
的index.html
{{1}}