[英]Error loading template for Spring Boot using Thymeleaf
我有一個使用Thymeleaf渲染模板的springBoot應用程序。 當我從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;
}
我檢查了jar文件,並且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似乎無法從該控制器加載模板。
很抱歉浪費大家的時間。 事實證明,像往常一樣,有一個愚蠢的簡單原因使我遇到了這個問題。 在創建新的控制器時,似乎我們監督了模板路徑中的前導“ /”。 因此,它的路徑不是“ XXX / path / to / file”,而是“ /XXX/path/to.file”。
我添加此代碼是為了讓其他可能遇到此問題的人受益。
在事后思考中,我認為應該在某個地方突出顯示該錯誤消息,因為該錯誤消息遠非描述性的。 前導“ /”不應停止加載模板,如果這樣,則該錯誤至少應指出發生了什么問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.