Ошибка загрузки шаблона для Spring Boot с использованием Thymeleaf - PullRequest
0 голосов
/ 12 июня 2018

У меня есть приложение springBoot, которое использует Thymeleaf для рендеринга шаблонов.Когда я запускаю приложение из Eclipse, все работает отлично.Однако, когда я пытаюсь собрать jar-файл и запустить его, один шаблон отказывается загружаться со следующим исключением:

Шаблон обработки исключений "/ XXX / form / importConfiguration": шаблон разрешения ошибок "/ XXX /form / importConfiguration ", шаблон может не существовать или может быть недоступен для любого из настроенных резолверов шаблонов

Код контроллера довольно прост:

@Controller
public class ImportConfigurationsController extends BaseController
{
   private static final Logger log = LoggerFactory.getLogger(ImportConfigurationsController.class);

   private static final String PATH_IMPORT_CONFIG = "/XXX/importConfigurations";
   private static final String PATH_INIT_IMPORT_CONFIG = "/XXX/initLoadingXMLConfiguration";
   private static final String PATH_IMPORT_CONFIG_FROM_XML = "/XXX/importConfigurationFromXML";
   private static final String TEMPLATE_IMPORT_CONFIG = "/XXX/form/importConfiguration";

   /**
    * Loads the import configuration page
    * 
    * @param model
    * @return
    * @throws Exception
    */
   @GetMapping(PATH_IMPORT_CONFIG)
   public String importConfiguration(Model model) throws Exception
   {
      log.trace("Enter Method importConfiguration. Params: {}", model);

      log.trace("Return Method importConfiguration.");
      return TEMPLATE_IMPORT_CONFIG;
   }

Я проверил банкуфайл, и HTML-файл существует.Кроме того, все остальные шаблоны, кроме этого, работают нормально.Кто-нибудь может мне помочь с этим?

РЕДАКТИРОВАТЬ: pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>XXXX</groupId>
    <artifactId>XXXX</artifactId>
    <version>1.7</version>

    <properties>
        <jar.filename>XXXX-${version}</jar.filename>

        <java.version>1.7</java.version>
        <commons.lang3-version>3.1</commons.lang3-version>
        <mybatis-version>3.4.1</mybatis-version>
        <ojdbc-version>11.2.0.4</ojdbc-version>
        <guava-version>19.0</guava-version>
        <commons-configuration-version>1.6</commons-configuration-version>
        <commons-jxpath-version>1.3</commons-jxpath-version>
        <javax-version>2.1</javax-version>

        <project.branch>trunk</project.branch>
        <deploy.dir>${project.basedir}/deploy</deploy.dir>
        <dist.dir>${deploy.dir}/XXXX/${project.branch}</dist.dir>
    </properties>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.4.RELEASE</version>
    </parent>

    <build>
        <finalName>${jar.filename}</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-antrun-plugin</artifactId>
                <executions>
                    <execution>
                        <!-- Run: runs Ant tasks for Maven -->
                        <id>copy-extra-files</id>
                        <phase>package</phase>
                        <goals>
                            <goal>run</goal>
                        </goals>
                        <configuration>
                            <!-- Ant targets to be executed -->
                            <target name="build-distribution">
                                <echo message="Deleting ${dist.dir} folder" />
                                <delete dir="${dist.dir}" />

                                <echo message="Copying application scripts to ${dist.dir} folder" />
                                <copy todir="${dist.dir}/application">
                                    <fileset dir="scripts" />
                                </copy>

                                <echo message="Copying SQL scripts to ${dist.dir}/sql folder" />
                                <copy todir="${dist.dir}/sql">
                                    <fileset dir="sql" />
                                </copy>

                                <echo message="Copying config to ${dist.dir}/config folder" />
                                <copy todir="${dist.dir}/application/config">
                                    <fileset dir="src/main/resources"
                                        includes="application.properties, messages.properties, log4j2.xml" />
                                </copy>

                                <echo message="Copying application's packaged jar file" />
                                <copy todir="${dist.dir}/application" verbose="true">
                                    <fileset file="target/${jar.filename}.jar" />
                                </copy>
                            </target>
                        </configuration>
                    </execution>
                    <execution>
                        <id>copy-extra-files</id>
                        <phase>none</phase>
                    </execution>
                </executions>
                <inherited>false</inherited>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-log4j2</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.tomcat.embed</groupId>
            <artifactId>tomcat-embed-el</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>${commons.lang3-version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.oracle</groupId>
            <artifactId>ojdbc6</artifactId>
            <version>${ojdbc-version}</version>
        </dependency>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>${mybatis-version}</version>
        </dependency>
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>${guava-version}</version>
        </dependency>
        <dependency>
            <groupId>javax.ws.rs</groupId>
            <artifactId>javax.ws.rs-api</artifactId>
            <version>${javax-version}</version>
        </dependency>
        <dependency>
            <groupId>commons-configuration</groupId>
            <artifactId>commons-configuration</artifactId>
            <version>${commons-configuration-version}</version>
        </dependency>
        <dependency>
            <groupId>commons-jxpath</groupId>
            <artifactId>commons-jxpath</artifactId>
            <version>${commons-jxpath-version}</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.6</version>
        </dependency>
    </dependencies>

    <repositories>
        <repository>
            <id>spring-releases</id>
            <name>Spring Releases</name>
            <url>https://repo.spring.io/libs-release</url>
        </repository>
    </repositories>

    <pluginRepositories>
        <pluginRepository>
            <id>spring-releases</id>
            <name>Spring Releases</name>
            <url>https://repo.spring.io/libs-release</url>
        </pluginRepository>
    </pluginRepositories>

</project>

ОБНОВЛЕНИЕ:

Кажется, что-то не так с самим контроллером.Когда я попытался вернуть имя другого шаблона в контроллер, который прекрасно загружался в другой контроллер, я получил то же исключение.Так что по какой-то причине Thymeleaf не может загружать шаблоны с этого контроллера.

1 Ответ

0 голосов
/ 12 июня 2018

Извините за трату времени всех.Как обычно, оказывается, что была тупо простая причина, по которой у меня возникла проблема.При создании новых контроллеров кажется, что мы наблюдали, что в пути шаблона был символ "/".Таким образом, вместо пути «XXX / путь / к / файлу» это был «/XXX/path/to.file».Я добавляю это для всех, кто может столкнуться с этой проблемой.В запоздалой мысли я думаю, что это должно быть где-то выделено, поскольку сообщение об ошибке было далеко не описательным.Символ «/» не должен останавливать загрузку шаблона, и если это так, ошибка должна как минимум указывать, что пошло не так.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...