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 -