Frühlingsstiefel - Thymeleaf

Thymeleaf ist eine Java-basierte Bibliothek, mit der eine Webanwendung erstellt wird. Es bietet eine gute Unterstützung für das Bereitstellen von XHTML / HTML5 in Webanwendungen. In diesem Kapitel erfahren Sie mehr über Thymeleaf.

Thymeleaf Vorlagen

Thymeleaf konvertiert Ihre Dateien in wohlgeformte XML-Dateien. Es enthält 6 Arten von Vorlagen wie unten angegeben -

  • XML
  • Gültiges XML
  • XHTML
  • Gültiges XHTML
  • HTML5
  • Legacy HTML5

Alle Vorlagen mit Ausnahme von Legacy HTML5 beziehen sich auf wohlgeformte gültige XML-Dateien. Mit Legacy HTML5 können wir die HTML5-Tags auf Webseiten einschließlich nicht geschlossener Tags rendern.

Internetanwendung

Sie können Thymeleaf-Vorlagen verwenden, um eine Webanwendung in Spring Boot zu erstellen. Sie müssen die folgenden Schritte ausführen, um eine Webanwendung in Spring Boot mithilfe von Thymeleaf zu erstellen.

Verwenden Sie den folgenden Code, um eine @ Controller-Klassendatei zu erstellen und den Anforderungs-URI in eine HTML-Datei umzuleiten.

package com.tutorialspoint.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class WebController {
   @RequestMapping(value = "/index")
   public String index() {
      return "index";
   }
}

Im obigen Beispiel lautet der Anforderungs-URI /indexund das Steuerelement wird in die Datei index.html umgeleitet. Beachten Sie, dass die Datei index.html im Vorlagenverzeichnis und alle JS- und CSS-Dateien im Klassenpfad im statischen Verzeichnis abgelegt werden sollten. Im gezeigten Beispiel haben wir eine CSS-Datei verwendet, um die Farbe des Textes zu ändern.

Sie können den folgenden Code verwenden und eine CSS-Datei in einem separaten Ordner erstellen css und benennen Sie die Datei als styles.css -

h4 {
   color: red;
}

Der Code für die Datei index.html ist unten angegeben -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "ISO-8859-1" />
      <link href = "css/styles.css" rel = "stylesheet"/>
      <title>Spring Boot Application</title>
   </head>
   <body>
      <h4>Welcome to Thymeleaf Spring Boot web application</h4>
   </body>
</html>

Der Projektexplorer wird im folgenden Screenshot gezeigt -

Jetzt müssen wir die Spring Boot Starter Thymeleaf-Abhängigkeit in unsere Build-Konfigurationsdatei einfügen.

Maven-Benutzer können der Datei pom.xml die folgende Abhängigkeit hinzufügen:

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

Gradle-Benutzer können der build.gradle-Datei die folgende Abhängigkeit hinzufügen:

compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'

Der Code für die Hauptdatei der Spring Boot-Anwendungsklasse ist unten angegeben:

package com.tutorialspoint.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
   public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
   }
}

Der Code für Maven - pom.xml ist unten angegeben -

<?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>com.tutorialspoint</groupId>
   <artifactId>demo</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>demo</name>
   <description>Demo project for Spring Boot</description>

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

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>

      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-thymeleaf</artifactId>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Der Code für Gradle - build.gradle ist unten angegeben -

buildscript {
   ext {
      springBootVersion = '1.5.8.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
dependencies {
   compile('org.springframework.boot:spring-boot-starter-web')
   compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'
   testCompile('org.springframework.boot:spring-boot-starter-test')
}

Sie können eine ausführbare JAR-Datei erstellen und die Spring-Boot-Anwendung mit den folgenden Maven- oder Gradle-Befehlen ausführen:

Verwenden Sie für Maven den folgenden Befehl:

mvn clean install

Nach "BUILD SUCCESS" finden Sie die JAR-Datei im Zielverzeichnis.

Verwenden Sie für Gradle den folgenden Befehl:

gradle clean build

Nach "BUILD SUCCESSFUL" finden Sie die JAR-Datei im Verzeichnis build / libs.

Führen Sie die JAR-Datei mit dem hier angegebenen Befehl aus -

java –jar <JARFILE>

Jetzt wurde die Anwendung auf dem Tomcat-Port 8080 wie unten gezeigt gestartet.

Drücken Sie nun die URL in Ihrem Webbrowser und Sie können die Ausgabe wie gezeigt sehen -

http://localhost:8080/index