JSF - Internasionalisasi

Internasionalisasi adalah teknik di mana pesan status, label komponen GUI, mata uang, tanggal tidak di-hardcode dalam program. Sebaliknya, mereka disimpan di luar kode sumber dalam bundel sumber daya dan diambil secara dinamis. JSF menyediakan cara yang sangat nyaman untuk menangani bundel sumber daya.

Langkah-langkah berikut diperlukan untuk menginternalisasi aplikasi JSF.

Langkah 1: Tentukan file properti

Buat file properti untuk setiap lokal. Nama harus dalam format <file-name> _ <locale> .properties.

Lokal default dapat dihilangkan dalam nama file.

messages.properties

greeting = Hello World!

messages_fr.properties

greeting = Bonjour tout le monde!

Langkah 2: Perbarui wajah-config.xml

wajah-config.xml

<application>
   <locale-config>
      <default-locale>en</default-locale>
      <supported-locale>fr</supported-locale>
   </locale-config>
   
   <resource-bundle>
      <base-name>com.tutorialspoint.messages</base-name>
      <var>msg</var>
   </resource-bundle>
</application>

Langkah 3: Gunakan resource-bundle var

home.xhtml

<h:outputText value = "#{msg['greeting']}" />

Contoh Aplikasi

Mari kita buat aplikasi uji JSF untuk menguji internasionalisasi di JSF.

Langkah Deskripsi
1 Buat proyek dengan nama helloworld di bawah paket com.tutorialspoint.test seperti yang dijelaskan di JSF - bab Aplikasi Pertama .
2 Buat folder sumber daya di bawah folder src → mai .
3 Buat folder com di bawah folder src → main → resource .
4 Buat folder tutorialspoint di bawah folder src → main → resources → com .
5 Buat file messages.properties di folder src → main → resource → com → tutorialspoint . Ubah seperti yang dijelaskan di bawah.
6 Buat file messages_fr.properties di folder src → main → resource → com → tutorialspoint . Ubah seperti yang dijelaskan di bawah.
7 Buat wajah-config.xml di WEB-INFf yang lebih lama seperti dijelaskan di bawah.
8 Buat UserData.java di bawah paket com.tutorialspoint.test seperti yang dijelaskan di bawah ini.
9 Ubah home.xhtml seperti yang dijelaskan di bawah ini. Jaga sisa file tidak berubah.
10 Kompilasi dan jalankan aplikasi untuk memastikan logika bisnis berfungsi sesuai kebutuhan.
11 Terakhir, buat aplikasi dalam bentuk file perang dan terapkan di Webserver Apache Tomcat.
12 Luncurkan aplikasi web Anda menggunakan URL yang sesuai seperti yang dijelaskan di bawah ini pada langkah terakhir.

messages.properties

greeting = Hello World!

messages_fr.properties

greeting = Bonjour tout le monde!

wajah-config.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<faces-config
   xmlns = "http://java.sun.com/xml/ns/javaee"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee 
   http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd"
   version = "2.0">
   
   <application>
      <locale-config>
         <default-locale>en</default-locale>
         <supported-locale>fr</supported-locale>
      </locale-config>
      
      <resource-bundle>
         <base-name>com.tutorialspoint.messages</base-name>
         <var>msg</var>
      </resource-bundle>
   </application>
</faces-config>

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;
import java.util.LinkedHashMap;
import java.util.Locale;
import java.util.Map;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.context.FacesContext;
import javax.faces.event.ValueChangeEvent;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;
   private String locale;

   private static Map<String,Object> countries;
      static {
      
      countries = new LinkedHashMap<String,Object>();
      countries.put("English", Locale.ENGLISH);
      countries.put("French", Locale.FRENCH);
   }

   public Map<String, Object> getCountries() {
      return countries;
   }

   public String getLocale() {
      return locale;
   }

   public void setLocale(String locale) {
      this.locale = locale;
   }

   //value change event listener
   public void localeChanged(ValueChangeEvent e) {
      String newLocaleValue = e.getNewValue().toString();
      
      for (Map.Entry<String, Object> entry : countries.entrySet()) {
         
         if(entry.getValue().toString().equals(newLocaleValue)) {
            FacesContext.getCurrentInstance()
               .getViewRoot().setLocale((Locale)entry.getValue());         
         }
      }
   }
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"   
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core">
   
   <h:head>
      <title>JSF tutorial</title>	 	
   </h:head>
   
   <h:body> 
      <h2>Internalization Language Example</h2>
      
      <h:form>
         <h3><h:outputText value = "#{msg['greeting']}" /></h3>
         
         <h:panelGrid columns = "2"> 
            Language : 
            <h:selectOneMenu value = "#{userData.locale}" onchange = "submit()"
               valueChangeListener = "#{userData.localeChanged}">
               <f:selectItems value = "#{userData.countries}" /> 
            </h:selectOneMenu> 
         </h:panelGrid> 
      
      </h:form>
   </h:body>
</html>

Setelah Anda siap dengan semua perubahan yang dilakukan, mari kita kompilasi dan jalankan aplikasi seperti yang kita lakukan di JSF - bab Aplikasi Pertama. Jika semuanya baik-baik saja dengan aplikasi Anda, ini akan memberikan hasil sebagai berikut.

Ubah bahasa dari dropdown. Anda akan melihat output berikut.