Java for Beginner
677 subscribers
560 photos
156 videos
12 files
860 links
Канал от новичков для новичков!
Изучайте Java вместе с нами!
Здесь мы обмениваемся опытом и постоянно изучаем что-то новое!

Наш YouTube канал - https://www.youtube.com/@Java_Beginner-Dev

Наш канал на RUTube - https://rutube.ru/channel/37896292/
Download Telegram
JSP и Thymeleaf как механизмы представления

В Spring MVC важное место занимают механизмы представления (view engines), которые отвечают за отображение данных на стороне клиента. JSP (JavaServer Pages) и Thymeleaf — популярные технологии, использующиеся для создания динамических страниц и интеграции с серверной логикой Spring.

1. JavaServer Pages (JSP)

JSP — это стандартная технология Java для создания динамических веб-страниц. Она позволяет внедрять Java-код в HTML при помощи тегов JSP, которые обрабатываются на сервере перед отправкой клиенту. JSP работает на сервере Apache Tomcat и является традиционным инструментом для Java-сервлетов.

Преимущества JSP:
Легкая интеграция с Java-сервлетами.
Мощный стандартный набор тегов JSP и возможность создания пользовательских тегов.
Хорошо подходит для MVC, позволяя отделять логику контроллера от представления.


Пример использования JSP: Создадим простую страницу home.jsp для отображения приветствия:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Home Page</title>
</head>
<body>
<h1>Welcome, ${username}!</h1>
</body>
</html>


Контроллер Spring для отображения этой страницы:
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class HomeController {

@GetMapping("/home")
public String home(Model model) {
model.addAttribute("username", "User");
return "home"; // Отображает home.jsp
}
}
Когда клиент отправляет запрос /home, контроллер добавляет переменную username в модель, а JSP обрабатывает ее и генерирует HTML-страницу с этим значением.


2. Thymeleaf

Thymeleaf — современный Java-шаблонизатор, который стал основным выбором для Spring MVC. В отличие от JSP, он позволяет рендерить HTML-страницы на сервере, не требуя компиляции в сервлеты. Thymeleaf может работать как в режиме "offline" (без сервера), так и "online" (на сервере), что упрощает разработку и отладку представлений.

Преимущества Thymeleaf:
Легко интегрируется со Spring MVC.
Поддерживает нативные HTML-шаблоны и позволяет работать с HTML-кодом даже вне сервера.
Имеет богатый набор встроенных функций и возможностей, таких как циклы, условия, работа с формами и локализация.


Пример использования Thymeleaf: Создадим шаблон home.html с использованием Thymeleaf для отображения приветствия:
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Home Page</title>
</head>
<body>
<h1>Welcome, <span th:text="${username}">User</span>!</h1>
</body>
</html>
Контроллер останется таким же, как и для JSP, так как Spring MVC подставит данные в модель одинаково для обеих технологий.


Сравнение JSP и Thymeleaf

JSP:
Поддержка HTML5 - ограничена
Обработка на сервере - необходим серверный контейнер
Поддержка Spring MVC - стандартная
Легкость отладки - ограничена

Thymeleaf:
Поддержка HTML5 - полная поддержка
Обработка на сервере - может работать offline
Поддержка Spring MVC - легкая интеграция и поддержка
Легкость отладки - высокая

Thymeleaf является более гибким и современным инструментом для работы с представлениями в Spring, а также поддерживает работу с HTML вне сервера. Это делает его популярным выбором для современных Java-разработчиков.

#Java #Training #Spring #JSP #Thymeleaf
Конфигурация шаблонов Thymeleaf в Spring

Thymeleaf — это мощный и гибкий шаблонизатор, который легко интегрируется с Spring Boot и Spring MVC, предоставляя возможности динамического отображения данных на основе HTML-шаблонов.

1. Конфигурация
Thymeleaf в Spring Boot

При использовании Spring Boot Thymeleaf включается автоматически, если вы добавите зависимость spring-boot-starter-thymeleaf в файл pom.xml:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>


После добавления этой зависимости Spring Boot настроит Thymeleaf как основной механизм представления. По умолчанию шаблоны Thymeleaf должны располагаться в папке src/main/resources/templates.

Пример использования Thymeleaf в Spring Boot

Создайте HTML-шаблон greeting.html в папке src/main/resources/templates:

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Greeting Page</title>
</head>
<body>
<h1 th:text="'Hello, ' + ${name} + '!'">Hello, User!</h1>
</body>
</html>


Создайте контроллер GreetingController:
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;

@Controller
public class GreetingController {

@GetMapping("/greeting")
public String greeting(@RequestParam(name = "name", required = false, defaultValue = "User") String name, Model model) {
model.addAttribute("name", name);
return "greeting";
}
}


Теперь при запросе к http://localhost:8080/greeting?name=John вы увидите страницу, приветствующую пользователя по имени: "Hello, John!".

2. Основные атрибуты Thymeleaf

Thymeleaf поддерживает множество атрибутов, которые позволяют динамически изменять содержимое страниц.

Вот некоторые из них:
th:text — вывод текста, заменяя существующее содержимое тега.
th:href — динамическое указание ссылки.
th:src — динамическое указание пути к изображению.
th:if / th:unless — условный рендеринг контента.
th:each — цикл для отображения коллекций.


Пример: Использование атрибутов th:if и th:each
В этом примере страница будет отображать список продуктов, используя Thymeleaf:
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Product List</title>
</head>
<body>
<h1>Product List</h1>
<ul>
<li th:each="product : ${products}" th:text="${product}">Product Name</li>
</ul>
</body>
</html>


Контроллер:
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

import java.util.Arrays;
import java.util.List;

@Controller
public class ProductController {

@GetMapping("/products")
public String productList(Model model) {
List<String> products = Arrays.asList("Laptop", "Tablet", "Smartphone");
model.addAttribute("products", products);
return "productList";
}
}
При обращении к /products пользователь увидит список товаров.


3. Конфигурация шаблонов Thymeleaf с кастомными настройками

Для кастомной настройки Thymeleaf можно использовать файл application.properties.

Например:
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
spring.thymeleaf.cache=false
Эти настройки изменяют путь к шаблонам, расширение файлов и управляют кэшированием (что полезно для разработки).


4. Поддержка международной локализации в Thymeleaf

Thymeleaf позволяет легко добавлять многоязычность в приложение. В Spring Boot нужно создать файл перевода, например, messages.properties, и добавить его в src/main/resources. Затем добавляем значения для разных языков (например, messages_en.properties, messages_ru.properties).

Пример:
# messages_en.properties
welcome.message=Welcome to our website!

# messages_ru.properties
welcome.message=Добро пожаловать на наш сайт!


Использование локализованных сообщений на странице:
<p th:text="#{welcome.message}">Welcome!</p>


#Java #Training #Spring #Thymeleaf