gpt4 book ai didi

css - Spring MVC 4 + Thymeleaf : static resources 404 error

转载 作者:太空宇宙 更新时间:2023-11-04 09:31:14 26 4
gpt4 key购买 nike

我正在使用 Spring 4.3.4 + Spring MVC + Thymeleaf 3.0.2 开发一个网络应用程序。顺便说一句,我还没有集成 Spring Security,所以没有任何安全策略。

问题很简单:浏览器没有加载静态资源(错误404)

这是我的元素文件夹结构,这是一个标准的 maven 结构(我把静态资源放在 /src/main/resources/static 上,但我也尝试过 /src/main/webapp//src/main/webapp/WEB-INF/):

enter image description here
例如,这就是我在页面上链接 CSS 的方式(相信我,文件 /src/main/resources/static/assets/css/style.css确实存在):

<link th:href="@{/assets/css/style.css}" type="text/css" />

据我所知,我不需要 ResourceHandler 来处理 /src/main/resourcess/static/assets/ 上的内容,它应该已经可用在 /assets/,但它不起作用,所以在我的 spring java 配置中我也做了一些尝试,例如:

@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("classpath:/static/assets/**").addResourceLocations("/assets/");
registry.addResourceHandler("classpath:/static/pages/**").addResourceLocations("/pages/");
}

在任何情况下,CSS 和 JS 文件都不可访问。

我的调度程序 servlet 映射到根/:

<servlet-mapping>
<servlet-name>myappDispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

如果我在浏览器上检查 HTML,我可以看到上面的标签变成了:

<link href="/myapp/assets/css/style.css" rel="stylesheet" type="text/css">

我觉得这很正确,对吧?

那么,为什么我尝试访问 css 时会收到 404 错误?我是不是忘记了什么重要的事情?

谢谢你,
卢卡

最佳答案

为了解决这个问题,我需要更改我的文件夹结构,将静态资源移动到 /webapp/ 文件夹中。我很确定有一种方法可以将 CSS 和 JS 保留到 /resources/ 文件夹中,但我没有成功,所以这是我的新文件夹结构:

enter image description here

然后我设置了资源处理程序映射:

@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
super.addResourceHandlers(registry);
registry.addResourceHandler("/assets/**").addResourceLocations("/assets/");
}

这是在 HTML 模板中使用的 link 标签(它适用于页面的动态和静态加载):

<link th:href="@{/assets/css/style.css}" href="../../assets/css/style.css"  rel="stylesheet" type="text/css" />

关于css - Spring MVC 4 + Thymeleaf : static resources 404 error,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40772391/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com