宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取

本文目录一览:

  • 1、java 多语言国际化
  • 2、java国际化的时候如何实现根据本地操作系统不同的语言显示不同的语言
  • 3、java国际化怎么实现
  • 4、如何创建java国际化类资源文件
  • 5、java 所说的国际化是什么意思?
  • 6、java中如何对时间做国际化处理啊

java 多语言国际化

国际化的英文为Internationalization,这个也太长了,所以它又称为I18n(英文单词 internationalization的首末字符i和n,18为中间的字符数)。

除了i18n还有L10n(localization),g11n(globalization),还有m17n(multilingualization),它们的区别是:

i18n支持多种语言,但是同一时间只能是英文和一种选定的语言,例如英文+中文、英文+德文、英文+韩文等等;

L10n(localization),支持2种语言,英文和另外一种语言(例如中文);

g11n(globalization),简单的理解可以认为g11n = i18n + L10n。

m17n(multilingualization)可以在同一时间支持多种语言,例如你可以在一个页面里看到中文、英文、德文和韩文。

为了使不同国家地区的人使用到适应他们环境和语言的软件或网站,国际化成为了Java的必要因素之一。

国际化机制在软件开发过程中,使得软件与特定的语言或地区脱钩。当我们做的软件被移植到其他国家时,不必更改软件本身的代码就可以适应当地区的使用了,所以,国际化是必须的。

那么在Java中如何实现国际化呢?

通过学习后,我也了解了一些必要的入门知识。

首先,我们可以通过测试代码获得本机操作系统的默认语言和区域。

查看默认语言和区域:

测试代码:

1 /**

2 * @author 巨亚红

3 * @date 2014-3-18 下午2:47:06

4 * @版本 V1.0 作者: 时间: 修改:

5 * @param args

6 */

7 public static void main(String[] args) {

8 Locale defaultLocale=Locale.getDefault();

9 System.out.println(“country=”+defaultLocale.getCountry());

10 System.out.println(“language=”+defaultLocale.getLanguage());

11 }

测试结果:

 

 如果将默认地区修改为美国的话,测试结果为:

 我们需要将硬编码文本转移到外部的资源文件里,建立两个国际化资源文件:

 名称=基本名称+Locale

1、设置资源文件。

MessgesBundle_en_US.properties:

k1=hello

k2=good bye

MessgesBundle_zh_CN.properties:

k1=\u4F60\u597D

k2=\u518D\u89C1

2、利用ResourceBundle.getBundle(baseName, locale)来找到MessgesBundle_en_US.properties文件。

ResourceBundle rb=ResourceBundle.getBundle(“MessgesBundle”, defaultLocale);

3、拿到k1和k2的value值。

System.out.println(“k1=”+rb.getString(“k1”));

System.out.println(“k2=”+rb.getString(“k2”));

结果是:

当前的地区设置成为英语(美国):

当前的地区设置成为中文(简体,中国):

 

4、占位符的使用。

设置当前Locale 

//Locale currentLocale=new Locale(“zh”, “CN”);

Locale currentLocale=new Locale(“en”, “US”);

添加占位符:

利用类MessageFormat

1 Locale currentLocale=new Locale(“en”, “US”);

2 ResourceBundle rb=ResourceBundle.getBundle(“MessgesBundle”, currentLocale);

3 MessageFormat mf=new MessageFormat(rb.getString(“k1”));

4 System.out.println(“k1=”+mf.format(new Object[]{“Jessica”}));

结果为:

如果改成中文:

1 Locale currentLocale=new Locale(“zh”, “CN”); //中文

2 ResourceBundle rb=ResourceBundle.getBundle(“MessgesBundle”, currentLocale);

3 MessageFormat mf=new MessageFormat(rb.getString(“k1”));

4 System.out.println(“k1=”+mf.format(new Object[]{“巨亚红”}));

结果为:

5、设置缺省国际化资源文件。

上面中我们设置的两个Locale已有资源文件,但是如果我们随便设置一个Locale,如果没有它对应的资源文件怎么办?那么就需要设置一个缺省的国际化资源文件了。只要添加一个名为MessgesBundle.properties的资源文件可以了,在里面进行相应的设置就OK了。

注意点:

缺省的Locale是由操作系统决定的。

Locale由语言和国家代码构成。

国际化资源文件是由baseName+Locale构成,如: MessgesBundle_en_US.properties

缺省的国际化资源文件是由baseName.properties命名的,如:MessgesBundle.properties

如果资源文件放在了包里,那么baseName就要加上包名了,否则找不到。

附上出处链接:

java国际化,java国际化占位符(Java国际化/本地化实战)-风君雪科技博客

java国际化的时候如何实现根据本地操作系统不同的语言显示不同的语言

java.util.Locale locale = Locale.getDefault();这个会根据当前系统的语言生成locale

1、获取本地的locale语言,

2、然后读取资源文件

java国际化怎么实现

以下分3点进行讲述

1、我们使用java.lang.Locale来实现java国际化。

java.lang.Locale代表特定的地理、政治和文化。需要Locale来执行其任务的操作叫语言环境敏感的操作。

构造一个系统默认的Locale:

Locale defaultLocale = Locale.getDefault();

String country = defaultLocale.getCountry();//返回国家地区代码

String language = defaultLocale.getLanguage();//返回国家的语言

String displayCountry = defaultLocale.getDisplayCountry();//返回适合向用户显示的国家信息

String displayLanaguage = defaultLocale.getDisplayLanaguage();//返回适合向用户展示的语言信息

String displayName = defaultLocale.getDisplayName();//返回适合向用户展示的语言环境名

加入当前Java虚拟机线程所处的操作系统的区域语言设置为“中文(简体,中国)”,则上边的运行结果依次将会是:

CN

zh

中国

中文

中文(中国)

根据国家地区和语言构造一个Locale(语言环境)

Locale currentLocale = new Locale(“zh”, ”CN”);

构造方法为:Locale(String language, String country);

2、使用ResouceBundle读取国际化资源文件

ResourceBundle资源包包含特定语言环境的对象。使用其可以加载并读取语言环境资源。

1. 轻松的本地化或者翻译成不同的语言

2. 一次处理多个语言环境

3. 以后可以轻松的进行修改,一遍支持更多的语言环境。

当程序需要特定于语言环境的对象时,它使用getBundle()方法加载ResourceBundle类

ResourceBundle rb = ResourceBundle.getBundle(“res.MessageBundle”, currentLocale);

其中,res.MessageBundle代表的是我们在src下建立了一个res文件夹,而res文件夹下有一个名为MessageBundle.properteis的资源文件。我们允许在此建立多个国际化资源文件:MessageBundle_zh_CN.properties;

MessageBundle_en_US.properteis;

其中MessageBundle就是要在构造ResourceBundle时使用的字符串,这个名字合法即可,不需要特定约束。后边的名字一定要遵循规则,resourceName_language_country.properteis;

然后我们使用rb.getString(key);就可以获取资源文件中的Key对应的value。

3、实际应用距离:struts

在jsp页面中,即可直接使用s:text name=”key”/来调用ResourceBundle资源文件中的内容

如何创建java国际化类资源文件

问题:关于一些大型项目中会使用不同语言版本的视图,比如在一个Java Web开发中,在struts中九提供了改种文件的配置项及在View中通过标签bean:message value=””来根据浏览器不同语言形式来展示页面,实现多语言的互操作。

这里自己将所遇到的这类问题,查看相关资料,通过JDK自带的相关API实现这种国际化操作。

使用到的类主要有:import Java.util.Locale; import java.util.ResourceBundle;还需要简单的国家化资源文件(针对不同语言有不同文件 .properties文件,键值对)

比如新建一个包com.xiaoli.test,里面放置两个国际化文件,中文(LDPC.properties)和英文(LDPE.properties)支持:

[java] view plain copy

psys.login.index=index.jsp\u9875/p

[java] view plain copy

sys.login.index=index.jsp page

上面键值对是指:index.jsp 页

而后建立相关测试类实现如下:

[java] view plain copy

package com.xiaoli.test;

import java.util.Locale;

import java.util.ResourceBundle;

public class ResourceMessage

{

private static ResourceMessage resourceMessage = null;

private ResourceBundle resourceMessage_zh = null;

private ResourceBundle resourceMessage_en = null;

private Locale local;

//此时该国际化资源文件为下面的完全限定类名访问,LDP为资源文件前缀

private static final String SOURCE_FILE_ZH= “com.xiaoli.test.LDPC”;

private static final String SOURCE_FILE_EN= “com.xiaoli.test.LDPE”;

private ResourceMessage()

{

//分别将两个文件绑定到相应的语言环境下

resourceMessage_zh = ResourceBundle.getBundle(SOURCE_FILE_ZH, Locale.CHINA);

resourceMessage_en = ResourceBundle.getBundle(SOURCE_FILE_EN,

Locale.ENGLISH);

}

/**

* 单例模式

* 只创建一个实例

* @return

* @see [类、类#方法、类#成员]

*/

public static ResourceMessage getInstance()

{

if (null == resourceMessage)

{

synchronized (ResourceMessage.class)

{

resourceMessage = new ResourceMessage();

}

}

return resourceMessage;

}

public String getMessage(String key)

{

return getMessage(key, local);

}

public String getMessage(String key, Locale local)

{

if (null == local)

{

local = Locale.getDefault();

}

String msg = null;

if (Locale.CHINA.equals(local))

{

msg = resourceMessage_zh.getString(key);

}

else if (Locale.ENGLISH.equals(local))

{

msg = resourceMessage_en.getString(key);

}

//如果找不到资源文件,返回key

if (null == msg || “”.equals(msg))

{

return key;

}

return msg;

}

/** 测试方法

* @param args

* @see [类、类#方法、类#成员]

*/

public static void main(String[] args)

{

String key = “sys.login.index”;

// String value = ResourceMessage.getInstance().getMessage(key, Locale.ENGLISH);

//使用当前默认的语言环境获取,这里为中文支持

String value = ResourceMessage.getInstance().getMessage(key);

System.out.println(value);

}

}

结果,根据手动设置的不同语言环境可以打印不同的值:

index.jsp页 和 index.jsp page

java 所说的国际化是什么意思?

国际化就是在你导入struts之后工程目录下的ApplicationResources.properties文件当你在struts-config.xml配置了:message-resources parameter=”xxx.xx.xxx.ApplicationResources” /比如简体中文的是:ApplicationResources_zh_CN.properties会自动根据你操作系统的语言环境转换语言,但是在你JSP网页上,必须要用struts标签

java中如何对时间做国际化处理啊

import java.util.*;

import java.text.*;

public class timeText {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

Date now = new Date();

Calendar cal = Calendar.getInstance();

DateFormat d1 = DateFormat.getDateInstance(); //默认语言(汉语)下的默认风格(MEDIUM风格,比如:2008-6-16 20:54:53)

String str1 = d1.format(now);

DateFormat d2 = DateFormat.getDateTimeInstance();//获取系统时间格式

String str2 = d2.format(now); //将时间格式转换成字符串

DateFormat d3 = DateFormat.getTimeInstance();

String str3 = d3.format(now);

DateFormat d4 = DateFormat.getInstance(); //使用SHORT风格显示日期和时间

String str4 = d4.format(now);

DateFormat d5 = DateFormat.getDateTimeInstance(DateFormat.FULL,DateFormat.FULL); //显示日期,周,时间(精确到秒)

String str5 = d5.format(now);

DateFormat d6 = DateFormat.getDateTimeInstance(DateFormat.LONG,DateFormat.LONG); //显示日期。时间(精确到秒)

String str6 = d6.format(now);

DateFormat d7 = DateFormat.getDateTimeInstance(DateFormat.SHORT,DateFormat.SHORT); //显示日期,时间(精确到分)

String str7 = d7.format(now);

DateFormat d8 = DateFormat.getDateTimeInstance(DateFormat.MEDIUM,DateFormat.MEDIUM); //显示日期,时间(精确到分)

String str8 = d8.format(now);//与SHORT风格相比,这种方式最好用

System.out.println(“用Date方式显示时间: ” + now);//此方法显示的结果和Calendar.getInstance().getTime()一样

System.out.println(“用DateFormat.getDateInstance()格式化时间后为:” + str1);

System.out.println(“用DateFormat.getDateTimeInstance()格式化时间后为:” + str2);

System.out.println(“用DateFormat.getTimeInstance()格式化时间后为:” + str3);

System.out.println(“用DateFormat.getInstance()格式化时间后为:” + str4);

System.out.println(“用DateFormat.getDateTimeInstance(DateFormat.FULL,DateFormat.FULL)格式化时间后为:” + str5);

System.out.println(“用DateFormat.getDateTimeInstance(DateFormat.LONG,DateFormat.LONG)格式化时间后为:” + str6);

System.out.println(“用DateFormat.getDateTimeInstance(DateFormat.SHORT,DateFormat.SHORT)格式化时间后为:” + str7);

System.out.println(“用DateFormat.getDateTimeInstance(DateFormat.MEDIUM,DateFormat.MEDIUM)格式化时间后为:” + str8);

}

}

运行结果:

用Date方式显示时间: Mon Jun 16 20:54:53 CST 2008

用DateFormat.getDateInstance()格式化时间后为:2008-6-16

用DateFormat.getDateTimeInstance()格式化时间后为:2008-6-16 20:54:53

用DateFormat.getTimeInstance()格式化时间后为:20:54:53

用DateFormat.getInstance()格式化时间后为:08-6-16 下午8:54

用DateFormat.getDateTimeInstance(DateFormat.FULL,DateFormat.FULL)格式化时间后为

:2008年6月16日 星期一 下午08时54分53秒 CST

用DateFormat.getDateTimeInstance(DateFormat.LONG,DateFormat.LONG)格式化时间后为

:2008年6月16日 下午08时54分53秒

用DateFormat.getDateTimeInstance(DateFormat.SHORT,DateFormat.SHORT)格式化时间后

为:08-6-16 下午8:54

用DateFormat.getDateTimeInstance(DateFormat.MEDIUM,DateFormat.MEDIUM)格式化时间

后为:2008-6-16 20:54:53

或者直接获取毫秒,但是感觉与你问题无关