Spring MVC и Thymeleaf - работает только отображение пути к классам - PullRequest
0 голосов
/ 02 января 2019

Интересно, почему я должен добавлять "classpath:" всегда в отображение ресурсов для Spring, это лучший метод?

В настоящее время мой проект настроен так, но я, если я удалю "classpath", он ничего не находит (а также я не могу предоставить правильную прямую ссылку).Для интеграции начальной загрузки мне даже пришлось использовать «webjars-locator», чтобы сделать веб-банки доступными (из-за отсутствия прозрачности).

Может кто-нибудь объяснить, почему необходим classpath (и нет прямой ссылки), и как я могунайти или перестроить проект, чтобы он работал правильно?

ResourceHandlers: @ Override

public void addResourceHandlers(final ResourceHandlerRegistry registry) {

        registry.addResourceHandler(
                "/webjars/**",
                "/img/**",
                "/css/**",
                "/js/**")
        .addResourceLocations(
                "classpath:/META-INF/resources/webjars/",
                "classpath:/static/img/",
                "classpath:/static/css/",
                        "classpath:/static/js/");

    }

index.htm:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:th="http://www.thymeleaf.org" xmlns:sec="http://www.thymeleaf.org/thymeleaf-extras-springsecurity3">
<head>
<title>Spring Security Example</title>

<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1" />

<link rel="stylesheet" type="text/css" th:href="@{/css/style.css}" />
<link rel="stylesheet" type="text/css" th:href="@{/webjars/bootstrap/4.2.1/css/bootstrap.min.css}" />

</head>
<body>
    <h1 class="color1">Hello, world! style</h1>

    <p>
        Click <a th:href="@{/hello}">here</a> to see a greeting.
    </p>


    <!-- include javascript in the footer -->
    **<script type="text/javascript" th:src="@{/webjars/jquery/3.2.1/jquery.min.js}"></script>
    <script type="text/javascript" th:src="@{/webjars/bootstrap/4.2.1/js/bootstrap.min.js}"></script>**
</body>
</html>

Project Structure

1 Ответ

0 голосов
/ 02 января 2019

Нормально использовать classpath. Если вы хотите дополнительно загрузить ресурсы из корневого пути, используйте

{"/", "classpath:/META-INF/resources/webjars/" ...}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...