Spring Boot - Internasionalisasi
Internasionalisasi adalah proses yang membuat aplikasi Anda dapat beradaptasi dengan berbagai bahasa dan wilayah tanpa perubahan teknis pada kode sumber. Dengan kata lain, Internasionalisasi adalah kesiapan Lokalisasi.
Dalam bab ini, kita akan belajar secara detail tentang Bagaimana menerapkan Internasionalisasi di Boot Musim Semi.
Dependensi
Kita membutuhkan ketergantungan Spring Boot Starter Web dan Spring Boot Starter Thymeleaf untuk mengembangkan aplikasi web di Spring Boot.
Maven
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
Gradle
compile('org.springframework.boot:spring-boot-starter-web')
compile group: 'org.springframework.boot', name: 'spring-boot-starter-thymeleaf'
LocaleResolver
Kami perlu menentukan Lokal default aplikasi Anda. Kita perlu menambahkan kacang LocaleResolver di aplikasi Spring Boot kita.
@Bean
public LocaleResolver localeResolver() {
SessionLocaleResolver sessionLocaleResolver = new SessionLocaleResolver();
sessionLocaleResolver.setDefaultLocale(Locale.US);
return sessionLocaleResolver;
}
LocaleChangeInterceptor
LocaleChangeInterceptor digunakan untuk mengubah Lokal baru berdasarkan nilai parameter bahasa yang ditambahkan ke permintaan.
@Bean
public LocaleChangeInterceptor localeChangeInterceptor() {
LocaleChangeInterceptor localeChangeInterceptor = new LocaleChangeInterceptor();
localeChangeInterceptor.setParamName("language");
return localeChangeInterceptor;
}
Untuk mendapatkan efek ini, kita perlu menambahkan LocaleChangeInterceptor ke dalam registry interseptor aplikasi. Kelas konfigurasi harus memperluas kelas WebMvcConfigurerAdapter dan mengganti metode addInterceptors ().
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(localeChangeInterceptor());
}
Sumber Pesan
Aplikasi Spring Boot secara default mengambil sumber pesan dari src/main/resourcesfolder di bawah classpath. Nama file pesan lokal default harusmessage.properties dan file untuk setiap lokal harus diberi nama sebagai messages_XX.properties. "XX" mewakili kode lokal.
Semua properti pesan harus digunakan sebagai nilai pasangan kunci. Jika ada properti yang tidak ditemukan di lokal, aplikasi menggunakan properti default dari file messages.properties.
Properti messages.properties default akan seperti yang ditunjukkan -
welcome.text=Hi Welcome to Everyone
Properti messages_fr.properties bahasa Prancis akan seperti yang ditunjukkan -
welcome.text=Salut Bienvenue à tous
Note - File sumber pesan harus disimpan sebagai format file "UTF-8".
File HTML
Di file HTML, gunakan sintaks #{key} untuk menampilkan pesan dari file properti.
<h1 th:text = "#{welcome.text}"></h1>
Kode lengkap diberikan di bawah ini
Maven - 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>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>
Gradle - build.gradle
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')
}
File kelas aplikasi Spring Boot utama diberikan di bawah ini -
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);
}
}
File kelas pengontrol diberikan di bawah ini -
package com.tutorialspoint.demo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class ViewController {
@RequestMapping("/locale")
public String locale() {
return "locale";
}
}
Kelas konfigurasi untuk mendukung Internasionalisasi
package com.tutorialspoint.demo;
import java.util.Locale;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.LocaleResolver;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import org.springframework.web.servlet.i18n.LocaleChangeInterceptor;
import org.springframework.web.servlet.i18n.SessionLocaleResolver;
@Configuration
public class Internationalization extends WebMvcConfigurerAdapter {
@Bean
public LocaleResolver localeResolver() {
SessionLocaleResolver sessionLocaleResolver = new SessionLocaleResolver();
sessionLocaleResolver.setDefaultLocale(Locale.US);
return sessionLocaleResolver;
}
@Bean
public LocaleChangeInterceptor localeChangeInterceptor() {
LocaleChangeInterceptor localeChangeInterceptor = new LocaleChangeInterceptor();
localeChangeInterceptor.setParamName("language");
return localeChangeInterceptor;
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(localeChangeInterceptor());
}
}
Sumber pesan - properti pesan seperti yang ditunjukkan -
welcome.text = Hi Welcome to Everyone
Sumber pesan - message_fr.properties adalah seperti yang ditunjukkan -
welcome.text = Salut Bienvenue à tous
File HTML locale.html harus ditempatkan di bawah direktori templates di classpath seperti yang ditunjukkan -
<!DOCTYPE html>
<html>
<head>
<meta charset = "ISO-8859-1"/>
<title>Internationalization</title>
</head>
<body>
<h1 th:text = "#{welcome.text}"></h1>
</body>
</html>
Anda dapat membuat file JAR yang dapat dieksekusi, dan menjalankan aplikasi Spring boot dengan menggunakan perintah Maven atau Gradle berikut -
Untuk Maven, gunakan perintah berikut -
mvn clean install
Setelah “BUILD SUCCESS”, Anda dapat menemukan file JAR di bawah direktori target.
Untuk Gradle, gunakan perintah berikut -
gradle clean build
Setelah "BUILD SUCCESSFUL", Anda dapat menemukan file JAR di bawah direktori build / libs.
Sekarang, jalankan file JAR dengan menggunakan perintah seperti yang ditunjukkan -
java –jar <JARFILE>
Anda akan menemukan bahwa aplikasi telah dimulai pada port Tomcat 8080.
Sekarang tekan URL http://localhost:8080/locale di browser web Anda dan Anda dapat melihat output berikut -
URL http://localhost:8080/locale?language=fr akan memberi Anda output seperti yang ditunjukkan -