5.13. Internationalization¶
Table of Contents
5.13.1. Overview¶
Internationalization is a process wherein the display of labels and messages in an application is not fixed to a specific language. It supports multiple languages. The language switching can be achieved by specifying a unit called “Locale” expressing language, country and region.
This section explains how to internationalize messages to display on the screen.
In order to internationalization, following requrements should be meeted.
- Text elements on the screen(code name, messages, labels of GUI components etc.) should be retrieve from external definitions such as properties file. (should not be hard-coding in the source code)
- The mechanism to specify the locale of the clients should be provided.
Methods to specify the locale are as follows:
- Using standard request header (specify the locale by language settings of browsers)
- Saving the locale into the Cookie using request parameter
- Saving the locale into the Session using request parameter
The image of switching locale is as follows:
Note
For internationalization of Codelist, refer to Codelist.
Note
When the error screen is to be internationalised, transition to error screen is performed by using MVC Controller of Spring. If a direct transition to error screen is performed without Spring MVC, it may happen that the message is not output in intended language.
Tip
The most commonly known abbreviation of internationalization is i18n. Internationalization is abbreviated as i18n because the number of letters between the first “i” and the last “n” is 18 i.e. “nternationalizatio”.
5.13.2. How to use¶
5.13.2.1. Configuration to define messages¶
To internationalize the messages on the screen, use the one of following MessageSourceimelementations for managing messages.
- org.springframework.context.support.ResourceBundleMessageSource
- org.springframework.context.support.ReloadableResourceBundleMessageSource
The information here explains an example of using the ResourceBundleMessageSource.
applicationContext.xml
<bean id="messageSource"
    class="org.springframework.context.support.ResourceBundleMessageSource">
    <property name="basenames">
        <list>
            <value>i18n/application-messages</value>  <!-- (1) -->
        </list>
    </property>
</bean>
| Sr. No. | Description | 
|---|---|
| (1) | Specify  i18n/application-messagesas base name of properties file.It is recommended to store message properties file under i18n directory to support internationalization. For MessageSource details and definition methods, refer to Message Management. | 
Example of storing properties files
Properties file should be created in accordance with the following rules.
- File name should be defined in application-messages_XX.propertiesformat. (Specify locale in XX portion)
- The messages defined in application-messages.propertiesshould be created in default language.
- Make sure you create application-messages.properties. If it does not exist, messages cannot be fetched fromMessageSourceandJspTagExceptionoccurs while setting the messages in JSP.
When creating property files as above, it is determined which to use the file as follows:
- When the locale resolved by LocaleResolveris zh,application-messages_zh.propertiesis used.
- when the locale resolved by LocaleResolveris ja,application-messages_ja.propertiesis used.
- When properties file does not exist corresponding to the locale resolved by LocaleResolver,application-messages.propertiesis used as default. (“_XX” portion does not exist in file name)
Note
The locate to use is determined in the following order until a properties file is found corresponding to the locale.
- Locale sent from clients
- Locale specified by JVM on which application server runs (it may not be set in some cases)
- Locale specified by OS on which application server runs
It is frequently misunderstood that default properties file is used when properties file does not exist corresponding to the locale sent from clients . In this case, then it is checked whether the file is available corresponding to the locale specified by the application server. If not found, finally the default properties file is used.
Tip
For description of message properties file, refer to Message Management.
5.13.2.2. Changing locale as per browser settings¶
5.13.2.2.1. Settings of AcceptHeaderLocaleResolver¶
If switch the locale using browser settings, use the AcceptHeaderLocaleResolver.
spring-mvc.xml
<bean id="localeResolver"
    class="org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver" /> <!-- (1) -->
| Sr. No. | Description | 
|---|---|
| (1) | Specify  org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolverin id attribute “localeResolver” of bean tag.If this  LocaleResolveris used, HTTP header “accept-language” is added for each request and locale gets specified. | 
Note
When LocaleResolver is not set, org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver is used by default; hence LocaleResolver need not be set.
5.13.2.2.2. Definition of messages¶
See the example of definition of messages below.
application-messages.properties
title.admin.top = Admin Top
application-messages_ja.properties
title.admin.top = 管理画面 Top
5.13.2.2.3. Implementation of JSP¶
See the example of implementaion of messages below.
include.jsp(Common jsp file to be included)
<%@ page session="false"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>
<%@ taglib uri="http://www.springframework.org/tags" prefix="spring"%>  <!-- (1) -->
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<%@ taglib uri="http://www.springframework.org/security/tags" prefix="sec"%>
<%@ taglib uri="http://terasoluna.org/functions" prefix="f"%>
<%@ taglib uri="http://terasoluna.org/tags" prefix="t"%>
| Sr. No. | Description | 
|---|---|
| (1) | When message is to be output in JSP, it is output using Spring tag library; hence custom tag needs to be defined. <%@taglib uri="http://www.springframework.org/tags" prefix="spring"%>should be defined. | 
Note
For details on common jsp files to be included, refer to Creating common JSP for include.
JSP file for screen display
<spring:message code="title.admin.top" />  <!-- (2) -->
| Sr. No. | Description | 
|---|---|
| (2) | Output the message using  <spring:message>which is a Spring tag library of JSP.In code attribute, set the key specified in properties. In this example, if locale is ja, “管理画面 Top” is output and for other locales, “Admin Top” is output. | 
5.13.2.3. Changing locale depending on screen operations dynamically¶
The method of dynamic changing the locale depending on screen operations etc. is effective in case of selecting a specific language irrespective of user terminal (browser) settings.
Following is an example of changing locale depending on screen operations.
To use the language selected by a user, chooose org.springframework.web.servlet.i18n.LocaleChangeInterceptor.
LocaleChangeInterceptoris an interceptor to save the locale value specified by the request parameter using org.springframework.web.servlet.LocaleResolver.
Select the implementation class of LocaleResolver from the following table.
| No | Implementation class | How to save locale | 
|---|---|---|
| org.springframework.web.servlet.i18n.SessionLocaleResolver | Save in server(using  HttpSession) | |
| org.springframework.web.servlet.i18n.CookieLocaleResolver | Save in client(using  Cookie) | 
Note
When org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver is used in LocaleResolver,
locale cannot be changed dynamically using org.springframework.web.servlet.i18n.LocaleChangeInterceptor.
5.13.2.3.1. How to define LocaleChangeInterceptor¶
If switching the locale using the request parameter, use the LocaleChangeInterceptor.
spring-mvc.xml
<mvc:interceptors>
  <mvc:interceptor>
    <mvc:mapping path="/**" />
    <mvc:exclude-mapping path="/resources/**" />
    <mvc:exclude-mapping path="/**/*.html" />
    <bean
      class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor">  <!-- (1) -->
    </bean>
    <!-- omitted -->
  </mvc:interceptor>
</mvc:interceptors>
| Sr. No. | Description | 
|---|---|
| (1) | Define  org.springframework.web.servlet.i18n.LocaleChangeInterceptorin interceptor of Spring MVC. | 
Note
How to change the name of request parameter to specify locale
<bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor"> <property name="paramName" value="lang"/> <!-- (2) --> </bean>
paramNameproperty, specify the name of request parameter. In this example, it is “request URL?lang=xx”.When paramName property is omitted, “locale” gets set. With “request URL?locale=xx”, it becomes enabled.
5.13.2.3.2. How to define SessionLocaleResolver¶
If saving the locale in the server side, use the  SessionLocaleResolver.
spring-mvc.xml
<bean id="localeResolver" class="org.springframework.web.servlet.i18n.SessionLocaleResolver">  <!-- (1) -->
    <property name="defaultLocale" value="en"/>  <!-- (2) -->
</bean>
| Sr. No. | Description | 
|---|---|
| (1) | Define id attribute of bean tag in “localeResolver” and specify the class wherein  org.springframework.web.servlet.LocaleResolveris implemented.In this example,  org.springframework.web.servlet.i18n.SessionLocaleResolverthat stores locale in session is specified.id attribute of bean tag should be set as “localeResolver”. By performing these settings,  SessionLocaleResolverwill be used at theLocaleChangeInterceptor. | 
| (2) | Specify Locale in  defaultLocaleproperty. When Locale cannot be fetched from the session, setup value ofvaluebecomes valid.Note When  | 
5.13.2.3.3. How to define CookieLocaleResolver¶
If saving the locale in the client side, use the  CookieLocaleResolver.
spring-mvc.xml
<bean id="localeResolver" class="org.springframework.web.servlet.i18n.CookieLocaleResolver">  <!-- (1) -->
      <property name="defaultLocale" value="en"/>  <!-- (2) -->
      <property name="cookieName" value="localeCookie"/>  <!-- (3) -->
</bean>
| Sr. No. | Description | 
|---|---|
| (1) | In id attribute “localeResolver” of bean tag, specify  org.springframework.web.servlet.i18n.CookieLocaleResolver.id attribute of bean tag should be set as “localeResolver”. By performing these settings,  CookieLocaleResolverwill be used at theLocaleChangeInterceptor. | 
| (2) | Specify Locale in  defaultLocaleproperty. When Locale cannot be fetched from Cookie, setup value ofvaluebecomes valid.Note When  | 
| (3) | The value specified in  cookieNameproperty is used as cookie name. If not specified, the value oforg.springframework.web.servlet.i18n.CookieLocaleResolver.LOCALEis used as default. It is recommended to change not to tell the user explicitly Spring Framework is used. | 
5.13.2.3.4. Messages settings¶
See the example below for messages settings.
application-messages.properties
i.xx.yy.0001 = changed locale
i.xx.yy.0002 = Confirm change of locale at next screen
application-messages_ja.properties
i.xx.yy.0001 = Localeを変更しました。
i.xx.yy.0002 = 次の画面でのLocale変更を確認
5.13.2.3.5. Implementation of JSP¶
See the example of implementation of JSP below.
JSP file for screen display
<a href='${pageContext.request.contextPath}?locale=en'>English</a>  <!-- (1) -->
<a href='${pageContext.request.contextPath}?locale=ja'>Japanese</a>
<spring:message code="i.xx.yy.0001" />
| Sr. No. | Description | 
|---|---|
| (1) | Submit the request parameter to switch the locale. Request parameter name is specified in  paramNameproperty ofLocaleChangeInterceptor. (In the example above, the default parameter name is used)In the above example, it is changed to English locale in English link and to Japanese locale in Japanese link. Hereafter, the selected locale is enabled. As “en” properties file does not exist, English locale is read from properties file by default. | 
Tip
- Spring tag library should be defined in common jsp files to be included.
- For details on common jsp files to be included, refer to Creating common JSP for include.


